JAVA通过数组按首字母排序怎么做?
自己封装的一个工具类,可以将汉字按照拼音的首字母排序,支持对Model和字典排序.只能对首字母排序,不支持第二个字母, 实现的原理就是创建一个A-Z的数组,数组中的元素是字典,字典中有两个元素,一个是title,就是当前的首字母 A-Z中的一个,另一个是保存当前title对应的元素的数组,对传入的数组进行遍历获得数组中的一个元素,如果是Model或者字典通过传入的key的值获得要排序的字符串,获得字符串的拼音的首字母,判断拼音的首字母是A-Z中的哪一个,然后放到数组中的对应的字典的数组中.
后来又做了一个对英文的首字母排序的程序,原理和上面的一样,还省略了将汉字转化为拼音的步骤。工具类的名称是:NH_OrderByPinYinFirstLetter。
代码:使用的时候直接调用下面的方法就行,是一个加号方法,第一个参数是保存要排序的元素的数组,第二个参数:如果数组中是Model或者字典,就写排序的依据的key值,如果数组中不是Model或字典,就写nil。
[objc] view plain copy
// 方法
+ (NSMutableArray *)baseOrderPinYinOnArr:(NSMutableArray *)arr ByKey:(NSString *)key 返回值的类
// 返回一个有24个元素的数组,数组里的元素是字典
// 字典里有两对键值对
// title : 当前的拼音首字母 A – Z
// datas : 当前的拼音首字母对应的model所组成的数组
使用java程序,将txt中的名字,按照以下要求进行排序: 1.按首字母A-Z的顺序,将名字
public class Luck {
public static void main(String[] args) {
int count = 677;// count,手动指定范围
// 确定字符串的长度
int length = 0;
int temp = count – 1;
while (temp 0) {
temp = (temp – temp % 26) / 26;
length++;
}
temp = Math.max(temp, 2);// 保证输出的最小长度
// 从1输出到count
for (int a = 1; a = count; a++) {
int i = a – 1;
String s = “”;
while (i 0) {
s = (char) (‘A’ + i % 26) + s;
i = (i – i % 26) / 26;
}
while (s.length() length) {
s = ‘A’ + s;
}
System.out.println(s);
}
}
}
java如何给中文名字 按拼音的首字母分组
FirstLetterUtil类
public class FirstLetterUtil { private static int BEGIN = 45217; private static int END = 63486; // 按照声母表示,这个表是在GB2312中的出现的第一个汉字,也就是说“啊”是代表首字母a的第一个汉字。 // i, u, v都不做声母, 自定规则跟随前面的字母 private static char[] chartable = {‘啊’, ‘芭’, ‘擦’, ‘搭’, ‘蛾’, ‘发’, ‘噶’, ‘哈’, ‘哈’, ‘击’, ‘喀’, ‘垃’, ‘妈’, ‘拿’, ‘哦’, ‘啪’, ‘期’, ‘然’, ‘撒’, ‘塌’, ‘塌’, ‘塌’, ‘挖’, ‘昔’, ‘压’, ‘匝’,}; // 二十六个字母区间对应二十七个端点 // GB2312码汉字区间十进制表示 private static int[] table = new int[27]; // 对应首字母区间表 private static char[] initialtable = {‘a’, ‘b’, ‘c’, ‘d’, ‘e’, ‘f’, ‘g’, ‘h’, ‘h’, ‘j’, ‘k’, ‘l’, ‘m’, ‘n’, ‘o’, ‘p’, ‘q’, ‘r’, ‘s’, ‘t’, ‘t’, ‘t’, ‘w’, ‘x’, ‘y’, ‘z’,};
// 初始化 static { for (int i = 0; i 26; i++) { table[i] = gbValue(chartable[i]);// 得到GB2312码的首字母区间端点表,十进制。 } table[26] = END;// 区间表结尾 }
/** * 根据一个包含汉字的字符串返回一个汉字拼音首字母的字符串 最重要的一个方法,思路如下:一个个字符读入、判断、输出 */ public static String getFirstLetter(String sourceStr) { String result = “”; String str = sourceStr.toLowerCase(); int StrLength = str.length(); int i; try { for (i = 0; i StrLength; i++) { result += Char2Initial(str.charAt(i)); } } catch (Exception e) { result = “”; } return result; }
/** * 输入字符,得到他的声母,英文字母返回对应的大写字母,其他非简体汉字返回 ‘0’ */ private static char Char2Initial(char ch) { // 对英文字母的处理:小写字母转换为大写,大写的直接返回 if (ch = ‘a’ ch = ‘z’) { return ch; } if (ch = ‘A’ ch = ‘Z’) {
return ch; } // 对非英文字母的处理:转化为首字母,然后判断是否在码表范围内, // 若不是,则直接返回。 // 若是,则在码表内的进行判断。 int gb = gbValue(ch);// 汉字转换首字母
if ((gb BEGIN) || (gb END))// 在码表区间之前,直接返回 { return ch; }
int i; for (i = 0; i 26; i++) {// 判断匹配码表区间,匹配到就break,判断区间形如“[,)” if ((gb = table[i]) (gb table[i + 1])) { break; } }
if (gb == END) {//补上GB2312区间最右端 i = 25; } return initialtable[i]; // 在码表区间中,返回首字母 }
/** * 取出汉字的编码 cn 汉字 */ private static int gbValue(char ch) {// 将一个汉字(GB2312)转换为十进制表示。 String str = new String(); str += ch; try { byte[] bytes = str.getBytes(“GB2312”); if (bytes.length 2) { return 0; } return (bytes[0] 8 0xff00) + (bytes[1] 0xff); } catch (Exception e) { return 0; } }}
在main方法中调用FirstLetterUtil类的getFirstLetter()方法,获取姓名的首字母。如:“刘德华”获取首字母是“ldh”。
public static void main(String s[])
{
System.out.print(getFirstLetter(“刘德华”));//获取文字首字母的拼音
}
在netbeans下运行结果如图显示。