java 中文一,二,到十,怎么排序

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java 中文一,二,到十,怎么排序相关的知识,希望对你有一定的参考价值。

具体是:数据库中有个属性是class:A级一班、A级二班。。。到A级十班;B级一班,B级二班。。。;C级一班。。。排序使得它是我们熟知的顺序。A到Z,一到十,首要A在前面,然后考虑一到十

不知道说得明白么。。。

如果按照数据库自己排序,会按照中文的拼音进行排序(A-Z)有实验过。如果要实现楼主这样的功能。我建议,增加两个字段,分别是等级(level,最好是约定一个与A级B级对应的数字,如A级填1)、班级号(classno,班级 填,1,2,3代表1班2班3班),两个字段就可以确定一个班级。然后SQL语句为 select 查询的内容 from 表名 order by level,classno (先按level,后按classno排序)追问

你的建议挺好

参考技术A 截取字符串啊,A级一班 B级一班,截取第一个字符substring(0,1);,AB可以直接排序。
截取第三个字符串,然后变成数字的排序,字母的随便
String ss0="A级一班";
ss0=ss0.substring(2,3);
if(ss0.equals("一"))
ss0 = "0";
追问

这个稍显麻烦,不过可以解决

参考技术B

常用数据库都有排序引擎,用sql语句排序就ok

select * from myTable order by 'class' asc

追问

这个我试过用按笔画 by nlssort(columnName,'NLS_SORT=SCHINESE_STROKE_M')
按部首 by nlssort(columnName,'NLS_SORT=SCHINESE_RADICAL_M')
按拼音 by nlssort(columnName,'NLS_SORT=SCHINESE_PINYIN_M');
都不能适用我,你的不知道为什么是:二三四一

追答

对于这样的情况,我有个建议

你可以单独建立一个表用来索引汉字,比如

create table index_char_Chinese(charIndex int primary key,charChinese not null unique);
insert into index_char_Chinese values(0,'零');
insert into index_char_Chinese values(1,'一');
insert into index_char_Chinese values(2,'二');
insert into index_char_Chinese values(3,'三');
insert into index_char_Chinese values(4,'四');
insert into index_char_Chinese values(5,'五');
insert into index_char_Chinese values(6,'六');
insert into index_char_Chinese values(7,'七');
insert into index_char_Chinese values(8,'八');
insert into index_char_Chinese values(9,'九');

然后用连接表查询,

用 grounp by substring(‘class’,0,1)对年级分组,

order by table index_char_Chinese.charIndex asc

这样会比你自己写算法好好一些

本回答被提问者采纳

算法---JAVA实现堆排序(大顶堆)

堆排序是一种树形选择排序方法,它的特点是:在排序的过程中,将array[0,...,n-1]看成是一颗完全二叉树的顺序存储结构,利用完全二叉树中双亲节点和孩子结点之间的内在关系,在当前无序区中选择关键字最大(最小)的元素。


1. 若array[0,...,n-1]表示一颗完全二叉树的顺序存储模式,则双亲节点指针和孩子结点指针之间的内在关系如下:


  任意一节点指针 i:父节点:i==0 ? null : (i-1)/2


            左孩子:2*i + 1


            右孩子:2*i + 2


2. 堆的定义:n个关键字序列array[0,...,n-1],当且仅当满足下列要求:(0 <= i <= (n-1)/2)


      ① array[i] <= array[2*i + 1] 且 array[i] <= array[2*i + 2]; 称为小根堆;


      ② array[i] >= array[2*i + 1] 且 array[i] >= array[2*i + 2]; 称为大根堆;


3. 建立大根堆:


  n个节点的完全二叉树array[0,...,n-1],最后一个节点n-1是第(n-1-1)/2个节点的孩子。对第(n-1-1)/2个节点为根的子树调整,使该子树称为堆。


  对于大根堆,调整方法为:若【根节点的关键字】小于【左右子女中关键字较大者】,则交换。


  之后向前依次对各节点((n-2)/2 - 1)~ 0为根的子树进行调整,看该节点值是否大于其左右子节点的值,若不是,将左右子节点中较大值与之交换,交换后可能会破坏下一级堆,于是继续采用上述方法构建下一级的堆,直到以该节点为根的子树构成堆为止。


  反复利用上述调整堆的方法建堆,直到根节点。


4.堆排序:(大根堆)


  ①将存放在array[0,...,n-1]中的n个元素建成初始堆;


  ②将堆顶元素与堆底元素进行交换,则序列的最大值即已放到正确的位置;


  ③但此时堆被破坏,将堆顶元素向下调整使其继续保持大根堆的性质,再重复第②③步,直到堆中仅剩下一个元素为止。


堆排序算法的性能分析:


  空间复杂度:o(1);


  时间复杂度:建堆:o(n),每次调整o(log n),故最好、最坏、平均情况下:o(n*logn);


  稳定性:不稳定


 


建立大根堆的方法:

建立完成后进行堆排序:

算法---JAVA实现堆排序(大顶堆)

 删除堆顶元素:

算法---JAVA实现堆排序(大顶堆)

对堆的插入操作:先将新节点放在堆的末端,再对这个新节点执行向上调整操作。


假设数组的最后一个元素array[array.length-1]为空,新插入的结点初始时放置在此处。

算法---JAVA实现堆排序(大顶堆)

进行测试:

 

以上是关于java 中文一,二,到十,怎么排序的主要内容,如果未能解决你的问题,请参考以下文章

如何将半页纸论文写到十页?

VBA 如何将数字转换为中文大写

请教:JAVA中,comparator接口如何对double型数据进行排序。

java怎么让数组的数字从大到小排序?

java怎么让数组的数字从大到小排序?

java中编写代码1到十的数字添加到Arraylist集合中,遍历该集合求出十个数字的总和以及平均值