MySort(选做)的实现

题目内容

注意:研究sort的其他功能,要能改的动代码,需要答辩

模拟实现Linux下Sort -t : -k 2的功能。

要有伪代码,产品代码,测试代码(注意测试用例的设计)

参考 Sort的实现。提交博客链接。

代码框架(题目给出)

import java.util.*;

public class MySort {
public static void main(String[] args) {
String[] toSort = {"aaa:10:1:1",
"ccc:30:3:4",
"bbb:50:4:5",
"ddd:20:5:3",
"eee:40:2:20"}; System.out.println("Before sort:");
for (String str : toSort) {
System.out.println(str);
}
Arrays.sort(toSort); System.out.println("After sort:");
for (String str : toSort){
System.out.println(str);
}
}
}

题目理解与实现

sort命令

  • -t:设定间隔符。题目中-t :即设定冒号作为间隔符
  • -k:指定列数,即被间隔符分割后的第几块区域

所以,此题实际指实现以冒号为分隔符分割数组每个元素,以分割后每个元素的第二列的大小对原数组进行排序

伪代码

获得字符数组元素个数
建立循环,逐一获得以冒号分隔后所需区域的值
按照该值的大小,对原字符数组重新进行排序
输出排序后的该字符数组

分隔符的实现

以往涉及到分解String对象的字符序列时,我使用都是使用Stringtokenizer类和Scanner类。但是这次的实现其实使用String类提供的split()方法(该方法见教材P189)就已经足够,它会将字符序列按照提供的分隔符进行分解,并且存为一个字符数组。我们采用此方法,就可以在这个分解出的字符数组中很轻易的得到我们想要的值。

排序的实现

思路一

这里的实现我们可以将所得到的值存为一个数组colunmn[],先对这个数组进行排序,然后建立两层循环,对column[]中的每个值,都遍历一次原数组,数值匹配则将该元素输出,最后输出完的结果即为排序后的结果。

思路二

思路一中的方法实际上是最后输出的内容为原数组排序后的结果,实际上并未对原数组进行任何顺序的改变,而且过程中建立了许多中间数组。于是我决定换一条思路,不用Arrays.sort()方法,而是自己来写排序方法。为了方便,我选择了使用特别熟练的冒泡排序,来对原数组进行重新排序。只需将if判断内容更改为判断该分隔区的内容即可。

产品代码

public class MySort {
public static void main(String[] args) {
String[] toSort = {"aaa:10:1:1",
"ccc:30:3:4",
"bbb:50:4:5",
"ddd:20:5:3",
"eee:40:2:20"}; System.out.println("Before sort:");
for (String str : toSort) {
System.out.println(str);
}
//args[0]获得我们想要排序的区域,注意这个值在后续我们放在数组中使用,因此存为area时要减1。
int area = Integer.parseInt(args[0])-1;
//获得原字符数组的元素个数
int len = toSort.length;
//冒泡排序
for(int i=0;i<len-1;i++){
for(int j=0;j<len-i-1;j++){
//if中的判断条件为每一条元素被冒号分隔后area列的内容的大小
if(Integer.valueOf(toSort[j].split(":")[area])>Integer.valueOf(toSort[j+1].split(":")[area])){
String tmp = toSort[j];
toSort[j]=toSort[j+1];
toSort[j+1]=tmp;
}
}
}
System.out.println("After sort:");
for (String str : toSort) {
System.out.println(str);
} }
}

测试代码

  • 将原代码中排序部分功能单独取出,写成代码如下:
public class MySort1 {
String[] strings = new String[100];
String sort(String[]strings,int n){
this.strings = strings;
int area =n-1;
int len=strings.length;
for(int i=0;i<len-1;i++){
for(int j=0;j<len-i-1;j++){
if(Integer.valueOf(strings[j].split(":")[area])>Integer.valueOf(strings[j+1].split(":")[area])){
String tmp = strings[j];
strings[j]=strings[j+1];
strings[j+1]=tmp;
}
}
}
String result ="";
for(int i=0;i<len;i++){
result+=strings[i]+" ";
}
return result; } }
  • 对上述代码进行测试,测试代码如下:
import junit.framework.TestCase;
import org.junit.Test;
public class MySort1Test extends TestCase {
MySort1 mySort1 =new MySort1();
String[] toSort = {"aaa:10:1:1",
"ccc:30:3:4",
"bbb:50:4:5",
"ddd:20:5:3",
"eee:40:2:20"};
String myresult = "aaa:10:1:1 ddd:20:5:3 ccc:30:3:4 eee:40:2:20 bbb:50:4:5 ";
String[] toSort2 = {"banana:30:5",
"apple:10:8",
"pear:90:7",
"orange:20:9"};
String myresult2 = "banana:30:5 pear:90:7 apple:10:8 orange:20:9 ";
@Test
public void testsort() throws Exception{
assertEquals(myresult,mySort1.sort(toSort,2));
assertEquals(myresult2,mySort1.sort(toSort2,3));
}
}
  • 测试结果截图:

MySort排序结果截图

参考

最新文章

  1. BCP 数据的导入和导出
  2. 基于UDP协议的socket编程示例
  3. 比较评测epoll,select,and poll 时间机制
  4. c# 进程间的通信实现之一简单字符串收发
  5. ue4 模块的构建和加载
  6. 作为程序员之 Vim(一)
  7. PAT 1011. A+B和C (15)
  8. HDU 1285 确定比赛名次(简单拓扑排序)
  9. C/C++ 文件操作
  10. 硬件描述语言Verilog设计经验总结
  11. mysql学习之中的一个:mysql安装
  12. Java的wait(), notify()和notifyAll()使用心得(转)
  13. HDU1716(全排列)
  14. Xcode相关常用快捷键搜集
  15. Metrics-server插件安装配置
  16. Sublime Text3搭建PHP开发环境
  17. R语言实战(四)—— 基本数据管理
  18. MSTP多生成树的配置
  19. [Python]利用type()动态创建类
  20. 白盒测试实践项目(day1)

热门文章

  1. 浏览器行为:Form表单提交
  2. 谷歌浏览器(Chrome)离线包的下载方法!
  3. Linux查看修改文件句柄数
  4. java笔记web
  5. postgres日常操作
  6. 安装MySQL数据库并开启远程访问
  7. LINUX修改path环境变量
  8. SSD学习笔记
  9. 韦东山嵌入式Linux学习笔记03--如何搭建软件环境
  10. service与pod关联