E-COM-NET
首页
在线工具
Layui镜像站
SUI文档
联系我们
推荐频道
Java
PHP
C++
C
C#
Python
Ruby
go语言
Scala
Servlet
Vue
MySQL
NoSQL
Redis
CSS
Oracle
SQL Server
DB2
HBase
Http
HTML5
Spring
Ajax
Jquery
JavaScript
Json
XML
NodeJs
mybatis
Hibernate
算法
设计模式
shell
数据结构
大数据
JS
消息中间件
正则表达式
Tomcat
SQL
Nginx
Shiro
Maven
Linux
LeetCode面试题
刷题日记 2024-12-9
LeetCode
:48. 旋转图像
48.旋转图像-力扣(
LeetCode
)找规律就行result[j][m-i-1]=matrix[i][j];借助了辅助数组,如果不使用辅助数组可以考虑用翻转的思想来求解classSolution{publicvoidrotate
大萌神Nagato
·
2025-02-28 18:19
leetcode
算法
java
力扣刷题139. 单词拆分
139.单词拆分-力扣(
LeetCode
)最开始是字符串从头开始遍历子字符串,遇到字典内有的单词则直接i+上这个单词的长度,最后看看是否整个字符串都能遍历完即可但是这么简单显然是错误的,没有考虑到如下的情况
大萌神Nagato
·
2025-02-28 18:19
leetcode
算法
力扣刷题121. 买卖股票的最佳时机
121.买卖股票的最佳时机-力扣(
LeetCode
)只需要遍历一次即可,遍历时记录遍历前的最小数值,然后用当前数值减去最小数值即可求出classSolution{publicintmaxProfit(int
大萌神Nagato
·
2025-02-28 18:19
leetcode
算法
职场和发展
刷题日记 2024-11-23 力扣Q53:最大子数组和
53.最大子数组和-力扣(
LeetCode
)方法:动态规划练了好久的动态规划,终于会写了解法一:暴力求解第一次是这样写的,但是超时了,当个思路看publicstaticvoidmaxSubArray1(
大萌神Nagato
·
2025-02-28 18:19
leetcode
算法
职场和发展
LeetCode
Java刷题笔记—155. 最小栈
155.最小栈设计一个支持push,pop,top操作,并能在常数时间内检索到最小元素的栈。简单难度。由于需要再常数时间检索到最小值,那么我们需要在每次添加或者删除栈元素之后立即得到最小值,因此我们需要再每次添加元素之后保存当前的最小值。因此,我们每次入栈2个元素,一个是入栈的元素本身,一个是当前栈元素的最小值,最小栈始终保证最小值在顶部,出栈同样是每次出栈两个元素。/***155.最小栈*设计一
刘Java
·
2025-02-28 17:45
leetcode
java
算法
155.
最小栈
JAVA面试常见题_基础部分_mybatis
面试题
1、什么是MyBatis?答:MyBatis是一个可以自定义SQL、存储过程和高级映射的持久层框架。2、讲下MyBatis的缓存答:MyBatis的缓存分为一级缓存和二级缓存,一级缓存放在session里面,默认就有,二级缓存放在它的命名空间里,默认是不打开的,使用二级缓存属性类需要实现Serializable序列化接口(可用来保存对象的状态),可在它的映射文件中配置3、Mybatis是如何进行分
茂茂在长安
·
2025-02-28 17:15
JAVA
mysql
java
面试
mybatis
LeetCode
102. 二叉树的层序遍历
文章目录题目要求:思路C++代码题目要求:给你二叉树的根节点root,返回其节点值的层序遍历。(即逐层地,从左到右访问所有节点)。思路首先想到的就是根节点入队取队头元素(出队),把队头节点的左右孩子入队。重复但如何要把每一层分别区分出来?★关键一个一个的出显然无法判断是第几层,所以考虑一层一层地出。用一个变量levelSize记录该层的节点个数,levelSize=queue.size()当lev
iiiiiankor
·
2025-02-28 16:09
LeetCode刷题之路
算法
队列
层序遍历
二叉树
LeetCode
111. 二叉树的最小深度 java题解
https://
leetcode
.cn/problems/minimum-depth-of-binary-tree/description/注意,跟二叉树的最大深度求解完全不同。
奔跑的废柴
·
2025-02-28 14:53
LeetCode
leetcode
java
算法
leetcode
1472. 设计浏览器历史记录 中等
你有一个只支持单个标签页的浏览器,最开始你浏览的网页是homepage,你可以访问其他的网站url,也可以在浏览历史中后退steps步或前进steps步。请你实现BrowserHistory类:BrowserHistory(stringhomepage),用homepage初始化浏览器类。voidvisit(stringurl)从当前页跳转访问url对应的页面。执行此操作会把浏览历史前进的记录全部
圣保罗的大教堂
·
2025-02-28 14:17
leetcode
每日一题
leetcode
消息队列(RocketMQ+Kafka)
消息丢失(ack确认机制,死信队列)消息堆积(增加消费者,增加消费能力,增加集群分担)高可用(集群,主从,多副本)高性能(集群,分区,多机部署,负载均衡)RocketMQ整体架构视频:小白debug的视频
面试题
八千里路云和月laiker
·
2025-02-28 14:16
算法
rocketmq
kafka
分布式
算法教程:岛的最大面积
问题描述我们将要演练的具体问题是问题
Leetcode
:岛屿的最大面积。在
Leetcode
上找到的直接问题描述是:给你一个mxn二进制矩阵网格。岛屿是一组1(代表陆地),以4个方向(水平或垂直)连接。
谏君之
·
2025-02-28 13:41
算法
redis
数据库
java常见
面试题
:什么是NIO(New IO)?NIO和IO有什么区别?
NIO(NewIO)是一种同步非阻塞的I/O模型,是I/O多路复用的基础,已经被越来越多地应用到大型应用服务器,成为解决高并发与大量连接、I/O处理问题的有效方式。NIO适用于处理大量并发连接和高性能的网络服务器开发,如聊天服务器、即时通讯服务器、游戏服务器等。这是因为NIO提供了非阻塞的网络I/O操作,可以在一个线程中同时处理多个连接,提高了服务器的并发性能。此外,NIO还适用于文件I/O和数据
广寒舞雪
·
2025-02-28 12:38
java
java
nio
开发语言
HIVE
面试题
总结
Hive依赖于HDFS存储数据,Hive将HQL转换成MapReduce执行,所以说Hive是基于Hadoop的一个数据仓库工具,实质就是一款基于HDFS的MapReduce计算框架,对存储在HDFS中的数据进行分析和管理。一、Hive架构用户接口:CLI(hiveshell)、JDBC/ODBC(java访问hive)、WEBUI(浏览器访问hive)元数据:元数据包括:表名、表所属的数据库(默
小余真旺财
·
2025-02-28 11:00
Hive
hive
Hive
面试题
什么是Hive?Hive是基于Hadoop的一个数据仓库工具,用来进行数据提取、转化、加载,这是一种可以存储、查询和分析存储在Hadoop中的大规模数据的机制。Hive数据仓库工具能将结构化的数据文件映射为一张数据库表,并提供SQL查询功能,能将SQL语句转变成MapReduce任务来执行。Hive的意义(最初研发的原因)?降低程序员使用Hadoop的难度,降低学习成本Hive的内部组成模块,作用
昨夜为你摘星
·
2025-02-28 11:59
Python面向对象
面试题
及参考答案
目录什么是面向对象编程?Python中的类和对象是什么?什么是继承?Python如何实现继承?什么是多态?Python如何实现多态?Python中的类属性和实例属性有什么区别?类属性和实例属性的访问优先级规则是什么?Python中的实例方法、类方法和静态方法有什么区别?静态方法、类方法、实例方法的参数传递差异是什么?什么是构造函数(init)?解释__init__方法与__new__方法的区别Py
大模型大数据攻城狮
·
2025-02-28 11:58
python
面试
继承
封装
接口隔离
弱引用
元类
leetcode
刷题-动态规划09
最佳买卖股票时机含冷冻期、714.买卖股票的最佳时机含手续费、股票总结188.买卖股票的最佳时机IV309.最佳买卖股票时机含冷冻期714.买卖股票的最佳时机含手续费股票总结188.买卖股票的最佳时机IV
leetcode
emmmmXxxy
·
2025-02-28 11:27
leetcode
动态规划
算法
leetcode
刷题-动态规划06
322.零钱兑换
leetcode
题目链接代码随想录文档讲解思路:完全背包整理:完全背包理论基础:装满这个背包可得的最大价值(遍历顺序可以颠倒)零钱兑换2:装满背包有多少种方法(每种方法不强调顺序,组合数
emmmmXxxy
·
2025-02-28 11:57
leetcode
动态规划
算法
web前端常见
面试题
html文件开头DOCTYPE作用DOCTYPE(文档类型)是HTML文档的开头,它指定了HTML文档使用的HTML版本及文档类型,告诉浏览器以哪种规范来解析HTML文档。它的作用有以下几个方面:声明HTML版本:DOCTYPE声明可以让浏览器知道使用哪个HTML版本来解析当前文档,从而根据规范来处理文档中的元素和属性。帮助浏览器正确解析文档:DOCTYPE声明可以确保浏览器以标准模式渲染页面,而
JackieDYH
·
2025-02-28 10:55
程序猿面试题
前端
javascript
vue
面试题
c语言概率产生字母,智邮普创c语言
面试题
---- 字母概率(示例代码)
题目描述小明最近对概率问题很感兴趣。一天,小明和小红一起玩一个概率游戏,首先小明给出一个字母和一个单词,然后由小红计算这个字母在这个单词中出现的概率。字母不区分大小写。例如,给定的字母是a,单词是apple,那么概率是0.20000。输入输入包含多组测试数据。每组数据包含一个字母和一个单词。单词的长度不超过200。输出对于每一个输入,输出对应的概率,结果保留5位小数。样例输入aapplecCand
飞跃思考
·
2025-02-28 10:46
c语言概率产生字母
c语言字母概率,C/C++知识点之智邮普创c语言
面试题
---- 字母概率
本文主要向大家介绍了C/C++知识点之智邮普创c语言
面试题
----字母概率,通过具体的内容向大家展示,希望对大家学习C/C++知识点有所帮助。题目描述小明最近对概率问题很感兴趣。
OK up
·
2025-02-28 10:46
c语言字母概率
说说 Spring MVC 的执行流程?
高频
面试题
:说说SpringMVC的执行流程?大家好,我是浮生,一个工作了十四年的java程序员!昨天,一个工作2年的粉丝在面试的时候,面试官要求他说SpringMVC的执行流程。
浮生带你学Java
·
2025-02-28 09:45
Java面试题
Spring
spring
mvc
java
LeetCode
第5题:最长回文子串
这道题是
LeetCode
上的第5题,乍一看,好像是在跟我们玩捉迷藏。回文子串是什么?它其
Gemini技术窝
·
2025-02-28 05:11
leetcode
算法
java
数据结构
leetcode
0008 - 字符串转换整数 (atoi) medium
1题目:字符串转换整数(atoi)请你来实现一个myAtoi(strings)函数,使其能将字符串转换成一个32位有符号整数。函数myAtoi(strings)的算法如下:空格:读入字符串并丢弃无用的前导空格("")符号:检查下一个字符(假设还未到字符末尾)为‘-’还是‘+’。如果两者都不存在,则假定结果为正。转换:通过跳过前置零来读取该整数,直到遇到非数字字符或到达字符串的结尾。如果没有读取数字
SuperCandyXu
·
2025-02-28 05:10
Leetcode
leetcode
算法
leetcode
006 Z 子型变换 - medium
1题目:Z子型变换将一个给定字符串s根据给定的行数numRows,以从上往下、从左到右进行Z字形排列。比如输入字符串为“PAYPALISHIRING”行数为3时,排列如下:PAHNAPLSIIGYIR之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:“PAHNAPLSIIGYIR”。请你实现这个将字符串进行指定行数变换的函数:stringconvert(strings,intnumR
SuperCandyXu
·
2025-02-28 05:40
Leetcode
leetcode
算法
c++
【Day47
LeetCode
】图论问题 Ⅴ
一、图论问题Ⅴ今天学习最小生成树算法–prim算法和kruskal算法。最小生成树是所有节点的最小连通子图,有n个节点则必有n-1条边将所有节点连接起来。如何选取n-1条边使得图中所有节点连接到一起,并且边的权值和最小,这就是最小生成树问题。1、prim算法–寻宝问题prim算法的思想是每次寻找距离最小生成树最近的节点,并加入到最小生成树中。prim主要有三步:1、选距离生成树最近节点;2、最近节
银河梦想家
·
2025-02-28 05:34
leetcode
图论
算法
【超详细】动态规划子序列问题总结
子序列就是在一个数组中按顺序挑选若干数,子数组是连续的子序列,视为特殊的子序列问题子序列最长递增子序列300.最长递增子序列-力扣(
LeetCode
)https://
leetcode
.cn/problems
周玄九
·
2025-02-28 02:41
动态规划
算法
Redis分布式存储案例
面试题
问:1~2亿条数据需要缓存,请问如何设计这个存储案例?答:单机单台肯定是不可能的,肯定是分布式存储。问:用redis如何落地?答:1、哈希取余分区(小厂回答)2、一致性哈希算法分区(中厂回答)3、哈希槽分区(大厂回答,推荐回答)1、哈希取余分区2亿条记录就是2亿个(k,v),我们单机不行必须要分布式多机,假设有3台机器构成一个集群,用户每次读写操作都是根据公式:hash(key)%N个机器台数,计
哎呀哎呀诶
·
2025-02-28 02:10
Redis
redis
分布式
数据库
Redis分布式缓存
面试题
为什么使用分布式缓存?1.提升性能降低延迟:将数据缓存在离应用更近的地方,减少数据访问时间。减轻数据库压力:缓存频繁访问的数据,减少对后端数据库的请求,提升系统响应速度。2.扩展性水平扩展:通过增加节点,分布式缓存可以轻松扩展,处理更大规模的数据和请求。负载均衡:数据分布在不同节点上,避免单点瓶颈,提升系统整体吞吐量。3.高可用性容错能力:即使某个节点故障,其他节点仍能继续提供服务,确保系统稳定运
hxj..
·
2025-02-28 01:38
面试
分布式
缓存
redis
分布式
分布式缓存
【
leetcode
hot 100 128】最长连续序列
暴力解决:将存如hashmap中,再从min_num到max_num中寻找hashmap中存在的连续数classSolution{publicintlongestConsecutive(int[]nums){//遍历数组,将存如hashmap中Mapmap=newHashMap0){min_num=nums[0];max_num=nums[0];}for(inti=0;imax_num){max_
longii11
·
2025-02-28 00:22
leetcode
算法
职场和发展
设计模式
面试题
汇总
目录设计模式
面试题
汇总一、设计模式基础二、具体设计模式(一)创建型模式(二)结构型模式(三)行为型模式一、设计模式基础什么是设计模式?为什么使用设计模式?
阿贾克斯的黎明
·
2025-02-27 23:17
java
设计模式
java
web前端开发
面试题
1.一些开放性题目1.自我介绍:除了基本个人信息以外,面试官更想听的是你与众不同的地方和你的优势。2.项目介绍3.如何看待前端开发?4.平时是如何学习前端开发的?5.未来三到五年的规划是怎样的?position的值,relative和absolute分别是相对于谁进行定位的?§absolute:生成绝对定位的元素,相对于最近一级的定位不是static的父元素来进行定位。§fixed(老IE不支持)
书亦何欢*
·
2025-02-27 23:44
基本
前端
LeetCode
HOT 100Ⅰ
目录DAY11:两数之和2:两数相加3:无重复字符的最长子串DAY25:最长回文子串DAY311:盛最多水的容器(太秒了多看这道题)15:三数之和DAY453:最大子数组和20:有效的括号70:爬楼梯DAY521:合并两个有序链表DAY622:括号生成DAY7215:数组中的第k个最大元素DAY8206:反转链表45:跳跃游戏-ⅡDAY9104:二叉树的深度121:买股票的最佳时机136:只出现一
喝口茶吧
·
2025-02-27 22:07
leetcode
算法
Java spring
面试题
及答案(1~11题)
1、SpringMVC的工作原理?●用户向服务器发送请求,请求被springMVC前端控制器DispatchServlet捕获;●DispatcherServle对请求URL进行解析,得到请求资源标识符(URL),然后根据该URL调用HandlerMapping将请求映射到处理器HandlerExcutionChain;●DispatchServlet根据获得Handler选择一个合适的Handl
蒙娜丽莎的Java
·
2025-02-27 20:48
java
面试
学习路线
java
spring
开发语言
github
mysql
HTML专题之语义化
前言石匠敲击石头的第3次有一道经典的前端
面试题
:如何理解HTML语义化?如果让我自己回答,我会说语义化会让HTML代码更利于维护,并且有利于SEO的优化。
·
2025-02-27 17:39
大模型最新
面试题
系列:深度学习基础(二)
21.解释模型容量与过拟合的关系,如何在理论上平衡两者?模型容量与过拟合的关系模型容量指的是模型能够学习的复杂模式的能力,通常与模型的参数数量、网络结构的复杂度等相关。过拟合是指模型在训练数据上表现很好,但在未见过的测试数据上表现不佳。当模型容量较低时,模型可能无法学习到数据中的复杂模式,导致欠拟合,即在训练集和测试集上的表现都较差。随着模型容量的增加,模型能够学习到更复杂的模式,在训练集上的表现
人肉推土机
·
2025-02-27 15:08
大模型最新面试题集锦大全
AI编程
人工智能
pytorch
python
面试
leetcode
41. 缺失的第一个正数
题目如下数据范围观察数据范围n方复杂度的算法铁定不行了。但是我们可以另辟蹊径:若一个数组长度为n且这个数组的数都是正常的(例如n=3[1,2,3])这样即返回答案最大为n+1若出现不正常数(例如n=3[1,2,5][1,1,2])那么显然答案应该是3是小于n+1的所以我们不妨这样推断如果这个数组正常那么每个数必然能刚好对应一个位置就像上面的正常数组1在02在13在2即出现nums[i]==i+1。
萌の鱼
·
2025-02-27 14:32
leetcode
算法
c++
数据结构
Leetcode
76 Minimum Window Substring
题目链接https://
leetcode
.com/problems/minimum-window-substring/题解可利用滑动窗口求解。有两个指针l和r。
xxxmmc
·
2025-02-27 13:51
leetcode
哈希算法
滑动窗口
Leetcode
980 Unique Path III
题意给定一个二维矩阵,0代表空地,1代表起点,-1代表墙,2代表终点,求从起点出发,走到终点,并且能够经过所有的空地,一共有几条唯一路径思考首先求多少条路径问题我们一开始会想到dp,但是这一题不行,因为我要经过所有的空地,所以必须dfs求解题解先计算出有多少不是墙的点。然后从起点开始做dfs,对每一层dfs到当前位置有多少个不是墙的点与之前算出的结果进行比对,如果相等并且此时已经遍历到了终点,那么
xxxmmc
·
2025-02-27 13:21
leetcode
深度优先
算法
Design
Leetcode
Design
Leetcode
FunctionalRequirementsUserscanviewalistofproblemsUsersviewthedetailedproblemandcodesolutionsUsersareablesumbittheircodeaccordingtodifferentlanguageandgettheanswer.Usersareabletohavethele
xxxmmc
·
2025-02-27 13:21
系统架构
【
leetcode
hot 100 11】移动零
一、暴力解法:两个for循环,外层循环遍历所有可能的左边界,内层循环遍历所有可能的右边界classSolution{publicintmaxArea(int[]height){intmax_area=0;for(inti=0;iarea?max_area:area;}}returnmax_area;}}错误分析:当涉及的数组较大时,会超出时间限制双指针:一个指向数组的头部,一个指向数组的尾部,然后
longii11
·
2025-02-27 13:50
leetcode
算法
职场和发展
leetcode
day23 54 螺旋矩阵
54螺旋矩阵给你一个m行n列的矩阵matrix,请按照顺时针螺旋顺序,返回矩阵中的所有元素。示例1:输入:matrix=[[1,2,3],[4,5,6],[7,8,9]]输出:[1,2,3,6,9,8,7,4,5]示例2:输入:matrix=[[1,2,3,4],[5,6,7,8],[9,10,11,12]]输出:[1,2,3,4,8,12,11,10,9,5,6,7]解题思路:设四个变量top,
星愿shining
·
2025-02-27 12:17
leetcode
矩阵
c#
LeetCode
141 Linked List Cycle和142 Linked List Cycle II
题目141LinkedListCycleGivenalinkedlist,determineifithasacycleinit.Followup:Canyousolveitwithoutusingextraspace?142LinkedListCycleIIGivenalinkedlist,returnthenodewherethecyclebegins.Ifthereisnocycle,retu
kongfy4307
·
2025-02-27 12:16
LeetCode
leetcode
LeetCode
(142)Linked List Cycle2
题目如下:Givenalinkedlist,returnthenodewherethecyclebegins.Ifthereisnocycle,returnnull.Followup:Canyousolveitwithoutusingextraspace?题目分析:本题是上一道题目的扩展。可以沿用上一题目的方式。使用一块一慢两个指针从起点开始行走。快指针每次走2步,慢指针每次走1步。如果链表中有环
feliciafay
·
2025-02-27 12:45
C++
LeetCode
C++ 二叉树的后序遍历 - 力扣(
LeetCode
)
点击链即可查看题目:145.二叉树的后序遍历-力扣(
LeetCode
)一、题目给你一棵二叉树的根节点root,返回其节点值的后序遍历。
XYLoveBarbecue
·
2025-02-27 11:44
C++练习
c++
leetcode
开发语言
Leetcode
141 Linked List Cycle and
Leetcode
142 Linked List Cycle II
题目链接https://
leetcode
.com/problems/linked-list-cycle/https://
leetcode
.com/problems/linked-list-cycle-ii
xxxmmc
·
2025-02-27 11:12
leetcode
算法
快慢指针
【
leetcode
】 最小差值 c++
目录一、
leetcode
908.最小差值I二、
leetcode
910.最小差值II一、
leetcode
908.最小差值I1.问题描述给你一个整数数组nums,和一个整数k。
m0_73805456
·
2025-02-27 10:35
力扣leetcode
算法
数据结构
leetcode
贪心算法
c++
进BAT必懂:大厂高频八股文
面试题
及参考答案(6万字长文)
目录解释Java中的自动装箱和拆箱机制,并举例说明。自动装箱与拆箱机制注意事项简述Java中的异常处理机制,包括try-catch-finally结构的使用。异常处理机制谈谈Java中的访问修饰符(public、private、protected、default)的作用范围和使用场景。访问修饰符使用场景什么是Java的注解?列举一些常见的注解并说明其用途。Java注解常见注解描述Java中的对象克
大模型大数据攻城狮
·
2025-02-27 10:34
大厂面经
BAT
多线程问题
Java后台面试
Java高频
Java并发
Java面试
Redis
面试题
----为什么要做Redis分区?
Redis分区,也称为分片(Sharding),是将数据分散存储到多个Redis实例上的一种策略。做Redis分区主要有以下几个方面的原因:扩展性突破单机内存限制:随着业务的发展,数据量会不断增大,而单个Redis实例的内存是有限的。通过分区可以将数据分散到多个Redis实例中,理论上可以不受单机内存的限制,从而存储更多的数据。例如,一个电商平台的商品缓存数据量巨大,单台Redis服务器无法容纳,
指尖下的技术
·
2025-02-27 08:54
Java面试题
redis
java
数据库
Redis
面试题
----MySQL 里有 2000w 数据,Redis 中只存 20w 的数据,如何保证 Redis 中的数据都是热点数据?
要保证Redis中存储的20w数据都是热点数据,可以从数据筛选和数据淘汰两个大的方面来考虑,以下是详细的实现思路和方法:数据筛选1.基于业务规则分析业务场景:不同的业务场景有不同的热点数据特征。例如,在电商系统中,热门商品、促销商品往往是热点数据;在新闻资讯系统中,最新发布、阅读量高的新闻是热点数据。根据业务的特点,确定热点数据的规则。定期同步:编写脚本或程序,根据业务规则从MySQL中筛选出符合
指尖下的技术
·
2025-02-27 08:24
Java面试题
redis
mysql
数据库
Java 设计模式
面试题
说一下开发中需要遵守的设计原则?设计模式中主要有六大设计原则,简称为SOLID,是由于各个原则的首字母简称合并的来(两个L算一个,solid稳定的),六大设计原则分别如下:1、单一职责原则单一职责原则的定义描述非常简单,也不难理解。一个类只负责完成一个职责或者功能。也就是说在类的设计中我们不要设计大而全的类,而是要设计粒度小、功能单一的类。比如我们设计一个类里面既包含了用户的一些操作,又包含了支付
code36
·
2025-02-27 08:52
Java面试题
设计模式
java
面试
上一页
78
79
80
81
82
83
84
85
下一页
按字母分类:
A
B
C
D
E
F
G
H
I
J
K
L
M
N
O
P
Q
R
S
T
U
V
W
X
Y
Z
其他