/*
 * 1,给定一个字符串数组。按照字典顺序进行从小到大的排序。
 * {"nba","abc","cba","zz","qq","haha"}
 *
 * 思路:
 * 1,对数组排序。可以用选择,冒泡都行。
 * 2,for嵌套和比较以及换位。
 * 3,问题:以前排的是整数,比较用的比较运算符,可是现在是字符串对象。
 *   字符串对象怎么比较呢?爽了,对象中提供了用于字符串对象比较的功能。
 *   
 * compareTo()方法的充分利用,字符串排序
 *      int compareTo(String anotherString) :当前String对象与anotherString比较。
      (1)相等关系返回0;compareTo 只在方法 equals(Object) 返回 true 时才返回 0。
     * (2)不相等时,从两个字符串第0个字符开始比较,返回第一个不相等的字符差,例如:"abcdefghijklmn"和"abcdefghijalmn"两个字符串,
     *     前面“abcdefghij”一样,再往后一个是k,一个是a,则"abcdefghijklmn".compareTo("abcdefghijalmn")返回'k'-'a'的差。为正数10
      (3)另一种情况,较长字符串的前面部分恰巧是较短的字符串,返回它们的长度差。"abcdefghijklmn"与"abcdefghij",
             前面一个字符串比后面一个字符串多"klmn",则返回长度差为4
  
 *
 */

下面使用了三种排序方法,分别为冒泡排序,选择排序,和插入排序,对字符串比较后排序:

public class StringSort {

    /**
* @param args
*/
public static void main(String[] args) { String[] arr = { "nba", "abc", "cba", "zz", "qq", "haha" };
printArray(arr);
sortString(arr);
printArray(arr); }
/**
* 冒泡排序一种写法
* @param arr
*/
public static void sortString(String[] arr) {
String temp = null;
for (int i = 0; i < arr.length - 1; i++) {
for (int j = i + 1; j < arr.length; j++) { if(arr[i].compareTo(arr[j])>0){//字符串比较用compareTo方法
temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
}
}
/**
* 冒泡排序,比较字符串的大小
* @param arr
*/
public static void bubbleSortString(String[]arr){
int s = arr.length;
for(int out = s-1;out>0;out--){
for(int in=0;in<out;in++){
if(arr[in].compareTo(arr[in+1])>0){
String temp = arr[in];
arr[in] = arr[in+1];
arr[in+1] = temp;
}
}
}
}
/**
* 使用选择排序,比较字符串的大小
* @param arr
*/
public static void selectedSortString(String[] arr){
int s = arr.length;
String temp;
int min;
for(int out=0;out<s-1;out++){
min = out;
for(int in=out+1;in<s;in++){
if(arr[in].compareTo(arr[min]) < 0){
min = in;//记录下来,每次比较min指针要移动,内循环执行完一次,才交换,确定最小的字符串
}
}
//一趟内循环min标记的数和我们最初标记的最小的数交换,最终最小的数排好
temp = arr[out];
arr[out] = arr[min];
arr[min] = temp;
} }
/**
*
* @param arr
* 插入排序,默认把第一个数视为有序,从第二个数开始,进行回插。
*/
public static void insertSortString(String[]arr){
String temp;
int in;
int s = arr.length;
for(int out=1;out < s;out++){
in = out; //in与out外循环保持一致
temp = arr[out];
while(in > 0 && temp.compareTo(arr[in-1]) < 0){//右边的数和左边已排序部门进行比较,进行回插入
arr[in] = arr[in-1];//向右移动,腾出空间
--in;
}
arr[in] = temp;//插入到正确的位置
}
} /**
* 打印字符串
* @param arr
*/ public static void printArray(String[] arr) {
System.out.print("[");
for (int i = 0; i < arr.length; i++) {
if (i != arr.length - 1)
System.out.print(arr[i] + ", ");
else
System.out.println(arr[i] + "]");
}
} }
 

java基础知识回顾之---java String final类普通方法的应用之字符串数组排序的更多相关文章

  1. java基础知识回顾之---java String final类普通方法

    辞职了,最近一段时间在找工作,把在大二的时候学习java基础知识回顾下,拿出来跟大家分享,如果有问题,欢迎大家的指正. /*     * 按照面向对象的思想对字符串进行功能分类.     *      ...

  2. java基础知识回顾之---java String final类普通方法的应用之“按照字节截取字符串”

    /*需求:在java中,字符串“abcd”与字符串“ab你好”的长度是一样,都是四个字符.但对应的字节数不同,一个汉字占两个字节.定义一个方法,按照最大的字节数来取子串.如:对于“ab你好”,如果取三 ...

  3. java基础知识回顾之---java String final类构造方法

    /** * String 构造方法学习 *     String(byte[ ] bytes):通过byte数组构造字符串对象. *     String(byte[] bytes, int offs ...

  4. java基础知识回顾之java Thread类学习(八)--java.util.concurrent.locks(JDK1.5)与synchronized异同讲解

    看API文档介绍几个方法:  JDK1.5中提供了多线程的升级解决方案: 特点: 1.将同步synchronized显示的替换成Lock                    2.接口Conditio ...

  5. java基础知识回顾之java Thread类学习(四)--java多线程安全问题(锁)

    上一节售票系统中我们发现,打印出了错票,0,-1,出现了多线程安全问题.我们分析为什么会发生多线程安全问题? 看下面线程的主要代码: @Override public void run() { // ...

  6. java基础知识回顾之java集合类-Properties集合

    /** java.lang.Object   |--java.util.Dictionary<K,V>      |--java.util.Hashtable<Object,Obje ...

  7. java基础知识回顾之---java String final类 容易混淆的java String常量池内存分析

    /** *   栈(Stack) :存放基本类型的变量数据和对象的引用,但对象本身不存放在栈中,而是存放在堆(new 出来的对象)或者常量池中(字符串常量对象存放  在常量池中). 堆(heap):存 ...

  8. java基础知识回顾之---java String final类普通方法的应用之“模拟字符串Trim方法”

    /* * 4,模拟一个trim功能一致的方法.去除字符串两端的空白  * 思路: * 1,定义两个变量. * 一个变量作为从头开始判断字符串空格的角标.不断++. * 一个变量作为从尾开始判断字符串空 ...

  9. java基础知识回顾之---java String final类普通方法的应用之“两个字符串中最大相同的子串”

    /* * 3,两个字符串中最大相同的子串. * "qwerabcdtyuiop" * "xcabcdvbn" *  * 思路: * 1,既然取得是最大子串,先看 ...

随机推荐

  1. 修改eclipse中tomcat的发布路径

    当我们在eclipse部署好tomcat的时候,默认这个项目是部署在eclipse\workspace\.metadata\.plugins\org.eclipse.wst.server.core\t ...

  2. 腾讯云 安全组配置及与MySQL 远程登录失败原因浅析

    前言,知道自己腾讯云服务器安全组配置并在安全组里开放了所有端口的用户可以粗略的看看下边的内容,否则就仔细看看吧. 因为有学习及业务需要,我要在腾讯云上安装了CentOS7.2版本的服务器上安装MySQ ...

  3. 13.mariadb-rhce考试解题思路

    1.安装mariadb ①yum install -y mariadb mariadb-server 或者 yum groupinstall -y mariadb 2.备份和还原数据库 ①备份:mys ...

  4. 安装php-posix

      1.安装php-posix 1 yum -y install php-process 2.验证是否安装上了 1 php -m|grep posix 1 posix  

  5. Linux下的vi编辑器与gcc工具的使用

    最近在网上找了些视频,自学了一点Linux环境下,C编程的方法. 注 vi与vim是有区别的,vim打开的源码文件其中的关键字是有颜色的. vi编辑器有3种模式,命令行模式,插入模式,底行模式. 如果 ...

  6. sql中更新数据库用到declare @a in

    declare @a in update TB_Class set @a=1,name='李小龙' where ID=1 这样就可以像更新哪个就更新哪个了 例如ibatisnet中需要更新的时候: & ...

  7. file与 byte[] 互转

    byte 转file String filepath="D:\\"+getName();          File file=new File(filepath);        ...

  8. 在项目中 background transiton 带来的"便利"与“坑”

    本文就两个例子跟大家分享一下background-image与background-size的渐变(transition)所带来的方便与“深坑” 首选,说说这东西好的地方,有时候在做PC项目的时候,可 ...

  9. php编写简单的页面跳转功能

    不多说,直接上. //确保magic_quotes_gpc在php.ini中移开启function CheckInput($value){ //去除反斜杠 if(get_magic_quotes_gp ...

  10. 通信录分组并且分组标签悬停划入划出(包含错误信息及修改)--第三方开源--PinnedSectionListView

    PinnedSectionListView在github上的链接地址是:https://github.com/beworker/pinned-section-listview . 下载下来后直接将Pi ...