D13

 1:String,StringBuffer,StringBuilder的区别?
 * A:String是内容不可变的,而StringBuffer,StringBuilder都是内容可变的。
 * B:StringBuffer是同步的,数据安全,效率低;StringBuilder是不同步的,数据不安全,效率高
 * 
 * 2:StringBuffer和数组的区别?
 * 二者都可以看出是一个容器,装其他的数据。
 * 但是呢,StringBuffer的数据最终是一个字符串数据。
 * 而数组可以放置多种数据,但必须是同一种数据类型的。
 * 
 * 3:形式参数问题
 * String作为参数传递
 * StringBuffer作为参数传递 
 * 
 * 形式参数:
 * 基本类型:形式参数的改变不影响实际参数
 * 引用类型:形式参数的改变直接影响实际参数
 * 
 * 注意:

 * String作为参数传递,效果和基本类型作为参数传递是一样的。

public static void main(String[] args) {
		String s1 = "hello";
		String s2 = "world";
		System.out.println(s1 + "---" + s2);// hello---world
		change(s1, s2);
		System.out.println(s1 + "---" + s2);// hello---world

		StringBuffer sb1 = new StringBuffer("hello");
		StringBuffer sb2 = new StringBuffer("world");
		System.out.println(sb1 + "---" + sb2);// hello---world
		change(sb1, sb2);
		System.out.println(sb1 + "---" + sb2);// hello---worldworld

	}

	public static void change(StringBuffer sb1, StringBuffer sb2) {
		sb1 = sb2;
		sb2.append(sb1);
	}

	public static void change(String s1, String s2) {
		s1 = s2;
		s2 = s1 + s2;
	}


4,把数组拼接成一个字符串

public static void main(String[] args) {
		// 定义一个数组
		int[] arr = { 44, 33, 55, 11, 22 };

		// 定义功能
		// 方式1:用String做拼接的方式
		String s1 = arrayToString(arr);
		System.out.println("s1:" + s1);

		// 方式2:用StringBuffer做拼接的方式
		String s2 = arrayToString2(arr);
		System.out.println("s2:" + s2);
	}

	// 用StringBuffer做拼接的方式
	public static String arrayToString2(int[] arr) {
		StringBuffer sb = new StringBuffer();

		sb.append("[");
		for (int x = 0; x < arr.length; x++) {
			if (x == arr.length - 1) {
				sb.append(arr[x]);
			} else {
				sb.append(arr[x]).append(", ");
			}
		}
		sb.append("]");

		return sb.toString();
	}

	// 用String做拼接的方式
	public static String arrayToString(int[] arr) {
		String s = "";

		s += "[";
		for (int x = 0; x < arr.length; x++) {
			if (x == arr.length - 1) {
				s += arr[x];
			} else {
				s += arr[x];
				s += ", ";
			}
		}
		s += "]";

		return s;
	}

5,把字符串反转

// 用StringBuffer的reverse()功能
	public static String myReverse2(String s) {
		// StringBuffer sb = new StringBuffer();
		// sb.append(s);

		// StringBuffer sb = new StringBuffer(s);
		// sb.reverse();
		// return sb.toString();

		// 简易版
		return new StringBuffer(s).reverse().toString();
	}

6,判断一个字符串是否是对称字符串

方式一

public static boolean isSame2(String s) {
		return new StringBuffer(s).reverse().toString().equals(s);
	}
方式二
public static boolean isSame(String s) {
		boolean flag = true;

		// 把字符串转成字符数组
		char[] chs = s.toCharArray();

		for (int start = 0, end = chs.length - 1; start <= end; start++, end--) {
			if (chs[start] != chs[end]) {
				flag = false;
				break;
			}
		}

		return flag;
	}

7.判断一个数据是否是int范围内的

             // public static final int MAX_VALUE
		System.out.println(Integer.MAX_VALUE);
		// public static final int MIN_VALUE
		System.out.println(Integer.MIN_VALUE);

8. * int -- String
 * String.valueOf(number)
 * String -- int
 * Integer.parseInt(s)

	public static void main(String[] args) {
		// int -- String
		int number = 100;
		// 方式1
		String s1 = "" + number;
		System.out.println("s1:" + s1);
		// 方式2
		String s2 = String.valueOf(number);
		System.out.println("s2:" + s2);
		// 方式3
		// int -- Integer -- String
		Integer i = new Integer(number);
		String s3 = i.toString();
		System.out.println("s3:" + s3);
		// 方式4
		// public static String toString(int i)
		String s4 = Integer.toString(number);
		System.out.println("s4:" + s4);
		System.out.println("-----------------");

		// String -- int
		String s = "100";
		// 方式1
		// String -- Integer -- int
		Integer ii = new Integer(s);
		// public int intValue()
		int x = ii.intValue();
		System.out.println("x:" + x);
		//方式2
		//public static int parseInt(String s)
		int y = Integer.parseInt(s);
		System.out.println("y:"+y);
	}

9,十进制到其他进制
 * public static String toString(int i,int radix)
 * 由这个我们也看到了进制的范围:2-36
 * 为什么呢?0,...9,a...z
 * 
 * 其他进制到十进制
 * public static int parseInt(String s,int radix)


10,看程序写结果
 * 注意:Integer的数据直接赋值,如果在-128到127之间,会直接从缓冲池里获取数据

public static void main(String[] args) {
		Integer i1 = new Integer(127);
		Integer i2 = new Integer(127);
		System.out.println(i1 == i2);
		System.out.println(i1.equals(i2));
		System.out.println("-----------");

		Integer i3 = new Integer(128);
		Integer i4 = new Integer(128);
		System.out.println(i3 == i4);
		System.out.println(i3.equals(i4));
		System.out.println("-----------");

		Integer i5 = 128;
		Integer i6 = 128;
		System.out.println(i5 == i6);
		System.out.println(i5.equals(i6));
		System.out.println("-----------");

		Integer i7 = 127;
		Integer i8 = 127;
		System.out.println(i7 == i8);
		System.out.println(i7.equals(i8));

		// 通过查看源码,我们就知道了,针对-128到127之间的数据,做了一个数据缓冲池,如果数据是该范围内的,每次并不创建新的空间
		// Integer ii = Integer.valueOf(127);
	}

11,自动装箱:把基本类型转换为包装类类型
 * 自动拆箱:把包装类类型转换为基本类型
 * 注意一个小问题:
 * 在使用时,Integer  x = null;代码就会出现NullPointerException。
 * 建议先判断是否为null,然后再使用。
public static void main(String[] args) {
		// 定义了一个int类型的包装类类型变量i
		// Integer i = new Integer(100);
		Integer ii = 100;
		ii += 200;
		System.out.println("ii:" + ii);

		// 通过反编译后的代码
		// Integer ii = Integer.valueOf(100); //自动装箱
		// ii = Integer.valueOf(ii.intValue() + 200); //自动拆箱,再自动装箱
		// System.out.println((new StringBuilder("ii:")).append(ii).toString());

		Integer iii = null;
		// NullPointerException
		if (iii != null) {
			iii += 1000;
			System.out.println(iii);
		}
	}

12.统计一个字符串中大写字母字符,小写字母字符,数字字符出现的次数。(不考虑其他字符)

public static void main(String[] args) {
		// 定义三个统计变量。
		int bigCount = 0;
		int smallCount = 0;
		int numberCount = 0;

		// 键盘录入一个字符串。
		Scanner sc = new Scanner(System.in);
		System.out.println("请输入一个字符串:");
		String line = sc.nextLine();

		// 把字符串转换为字符数组。
		char[] chs = line.toCharArray();

		// 历字符数组获取到每一个字符
		for (int x = 0; x < chs.length; x++) {
			char ch = chs[x];

			// 判断该字符
			if (Character.isUpperCase(ch)) {
				bigCount++;
			} else if (Character.isLowerCase(ch)) {
				smallCount++;
			} else if (Character.isDigit(ch)) {
				numberCount++;
			}
		}

		// 输出结果即可
		System.out.println("大写字母:" + bigCount + "个");
		System.out.println("小写字母:" + smallCount + "个");
		System.out.println("数字字符:" + numberCount + "个");
	}


13,冒泡排序

/**
 *  冒泡排序
 *  冒泡排序的规则是相邻的两个数相比较大的数向右边和小的数交换位置
 *
 */
public class Demo {
public static void main(String[] args) {
	int[] arr={12,11,65,34,43,75,23,53};
	for(int i=0;i<arr.length;i++){
		for(int j=0;j<arr.length-1-i;j++){
			int temp=arr[j];
			if(arr[j]>arr[j+1]){
				arr[j]=arr[j+1];
				arr[j+1]=temp;
				
			}
		}
	}
}
}


14.选择排序

/**
 * 
 * 选择排序
 * 规则是:从0处依次和后面的元素比较,
 *
 */
public class Demo2 {
public static void main(String[] args) {
	int[] arr={12,11,65,34,43,75,23,53};
	for(int i=0; i<arr.length ;i++){
		for(int j=i; j<arr.length; j++){
			int temp=arr[i];
			if(arr[i]>arr[j]){
				arr[i]=arr[j];
				arr[j]=temp;
			}
		}
	}
	String str="";
	for(int a=0;a<arr.length;a++){
		str+=arr[a]+",";
	}
	System.out.println(str);
}
}

15,把字符串中的字符进行排序。

public static void main(String[] args) {
		String str="khjcxvasdfcsdf";
		char[] chr=str.toCharArray();
		for(int i=0;i<chr.length;i++){
			for(int j=i;j<chr.length-1;j++){
				char temp=chr[i];
				if(chr[i]>chr[j]){//如果chr[i]大于chr[j],
					chr[i]=chr[j];//就chr[i]的值替换成chr[j] 大值替换成小值,格式就是从小到大
					chr[j]=temp;
					
				}
				
			}
			
		}
		
		String str2=String.valueOf(chr);
		System.out.println(str2);

}

16.查找:
 * 基本查找:数组元素无序(从头找到尾)

//基本查找
        int index=-1;
    	for(int i=0;i<arr.length;i++){
    		if(arr[i]==value){
    			index=i;
    		}
    	}
    	if(index==-1){
    		System.out.println("没找到");
    	}else{
    		System.out.println(index);
    	}


 * 二分查找(折半查找):数组元素有序

//二分查找
	public static int getIndex(int[] arr,int value){
		//定义最大索引,最小索引
		int max = arr.length -1;
		int min = 0;
		
		//计算出中间索引
		int mid = (max +min)/2;
		
		//拿中间索引的值和要查找的值进行比较
		while(arr[mid] != value){
			if(arr[mid]>value){
				max = mid - 1;
			}else if(arr[mid]<value){
				min = mid + 1;
			}
			
			//加入判断
			if(min > max){
				return -1;
			}
			
			mid = (max +min)/2;
		}
		
		return mid;
	}


17,Arrays:针对数组进行操作的工具类。比如说排序和查找。
 * 1:public static String toString(int[] a) 把数组转成字符串
 * 2:public static void sort(int[] a) 对数组进行排序
 * 3:public static int binarySearch(int[] a,int key) 二分查找

你可能感兴趣的:(D13)