太自由

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
 1 package cn.itcast.api.String.test;
 2 
 3 public class StringTest_1 {
 4 
 5     public static void main(String[] args) {
 6 
 7         String s1 = "asdfitcastghijfghjk";
 8         String s2 = "xcitcastvbnm";
 9 
10         String maxSubStirng = getMaxSubstring(s2, s1);
11         System.out.println("maxSubString:" + maxSubStirng);
12         /*
13          * 作业1:获取两个字符串的最大相同子串。 "asdfitcastghijfghjk" "xcitcastvbnm"
14          * 
15          * 思路: 1,先明确两个字符串的长短,在长串中判断短串是否存在。 2,存在,已找到,说明短串就是最大的相同。
16          * 不存在,就将短串按照长度递减的方式,获取短串中的子串,并到长串中判断。 3,一旦存在,便结束查找。
17          */
18 
19     }
20 
21     private static String getMaxSubstring(String s1, String s2) {
22         String max, min;
23         // 明确哪个是长串,哪个是短串。
24         max = (s1.length() > s2.length()) ? s1 : s2;
25         min = max.equals(s1) ? s2 : s1;
26 
27         // 验证max和min.
28         /*
29          * System.out.println("max:"+max); System.out.println("min:"+min);
30          */
31 
32         for (int i = 0; i < min.length(); i++) {
33             for (int start = 0, end = min.length() - i; end < min.length(); start++, end++) {
34                     String temp = min.substring(start,end);
35                     if(max.contains(temp)){
36                         return temp;
37                     }
38             }
39         }
40         return null;
41     }
42 
43 }
 1 package cn.itcast.api.String.test;
 2 
 3 import java.util.Arrays;
 4 
 5 public class StringTest_2 {
 6 
 7     public static void main(String[] args) {
 8         String str = "cfdasbv";
 9         str = sortStringByChars(str);
10         System.out.println("str="+str);
11 
12     }
13     /*
14      * 
15      * 作业2:对字符串中字符进行自然顺序排序。
16      * cfdasbv--->abcdfsv
17      * 
18      * 思路:
19      * 1,排序都是对数组排序。
20      * 2,数组中的元素都是在字符串中,把字符串转成数组。
21      * 3,对数组排序。
22      * 4,将排序后的数组转成字符串。
23      */
24 
25     public static String sortStringByChars(String str) {
26         //1,将字符串转成数组。转成字符数组。
27         char[] chs = getArray(str);
28         //2,对数组排序。
29         sort(chs);
30         //3,将排序后的数组转成字符串。返回。
31         return new String(chs);
32     }
33 
34     private static void sort(char[] chs) {
35         Arrays.sort(chs);
36         
37     }
38 
39     /**
40      * 将字符串转成字符数组。
41      * @param str
42      * @return
43      */
44     private static char[] getArray(String str) {
45         // TODO Auto-generated method stub
46         return str.toCharArray();
47     }
48 
49 }
 1 package cn.itcast.api.String.test;
 2 
 3 public class StringTest_3 {
 4     public static void main(String[] args){
 5         String str = "   it  cast    ";
 6 //        String s1 = str.trim();
 7         String s1 = myTrim(str);
 8         System.out.println("-"+s1+"-");
 9     }
10 
11     /**
12      * 模拟trim功能。
13      * 
14      */
15     public static String myTrim(String str){
16             
17         //定义两个变量,一个记录头,一个记录尾。
18         int start = 0;
19         int end  =str.length()-1;
20         
21         //2,获取头部非空白的位置,
22         while(start<=end && str.charAt(start)==' '){
23             start++;
24         }
25         //2,获取尾部非空白的位置,
26         while(start<=end && str.charAt(end)==' '){
27             end--;
28         }
29         
30         //截取字符串。
31         return str.substring(start, end+1);
32     }
33 }
 1 package cn.itcast.api.wrapper.demo;
 2 
 3 public class WrapperDemo {
 4 
 5     public static void main(String[] args) {
 6         /*
 7          * 场景:通过文本框获取用户输入的数字数据,可是得到的都是字符串。
 8          * 如果想要对字符串中的数字进行运算,必须要将字符串转成数字。
 9          * JAVA提供了相应的解决对象。
10          * 基本数据类型对象包装类:Java将基本数据类型值封装成对象。
11          * 封装成对象有什么好处?因为可以提供更多的操作基本数值的方法。
12          * 
13          * byte     Byte
14          * short    Short
15          * int         Integer
16          * long        Long
17          * float    Float
18          * double    Double
19          * boolean    Boolean
20          * char        Character
21          */
22         
23         //学习一下整数Integer
24         /*
25          * 基本类型对象包装类特点:
26          * 1,用于在基本数据类型和字符串之间进行转换。
27          * int parseInt(String);
28          * byte parseByte(String);
29          * boolean parseBoolean(String);
30          * 
31          * xxx parseXxx(String);
32          * 只有Character没哟解析方法。
33          * 
34          * 
35          */
36         
37         /*System.out.println(Integer.MAX_VALUE);
38         System.out.println(Integer.toBinaryString(10));
39         System.out.println(Integer.toBinaryString(-6));*/
40         
41         //1,字符串--->基本数值。结果:基本数值(字符串)演示Integer  int(String)
42         
43         System.out.println(Integer.parseInt("123")+2);//NumberFormaExctpioon
44         System.out.println(Integer.parseInt("2222", 10));//按照指定的进制进行转换。
45         
46         //2,基本数值转成字符串。34+""  String.valueOf(34)Integer.toString(int);
47         System.out.println(34+5);
48         
49         //3,基本数值---》包装对象。
50         Integer i = new Integer(4);
51         Integer ii = Integer.valueOf("4");
52         
53         //包装对象---》基本数据类型
54         int num = i.intValue();
55         System.out.println(num);
56     }
57 
58 }
 1 package cn.itcast.api.wrapper.demo;
 2 
 3 public class WrapperDemo2 {
 4 
 5     public static void main(String[] args) {
 6         
 7 //        int i = 4;
 8 //        Integer i = new Integer(4);
 9 //        JDK1.5以后,有了一个包装类的新特性。目的简化书写。自动装箱
10         Integer i = 4;//自动装箱。Integer.valueOf(4);
11         i = i+5;//原理是:等号右边将i对象转成基本数值。i.intValue()+5;加法运算后,在此装箱。
12         //i = Integer.valueOf(i.inValue()+5);
13         System.out.println(i);
14         
15         Integer a = new Integer(3);
16         Integer b = new Integer(3);
17         System.out.println(a==b);
18         System.out.println(a.equals(b));
19         
20         System.out.println("===============");
21         Integer x = 127;
22         Integer y = 127;
23         System.out.println(x==y);
24         System.out.println(x.equals(y));
25 
26     }
27 
28 }
 1 //WrapperTest.java
 2 package cn.itcast.api.wrapper.demo;
 3 
 4 import java.util.Arrays;
 5 
 6 public class WrapperTest {
 7 
 8     public static void main(String[] args) {
 9         /*
10          * 练习:面试题:
11          * "23 9 -4 18 100 7";
12          * 要求对这串数字按照从大到小排序,生成一个数值有序的字符串。
13          */
14         String numString = "23 9 -4 18 100 7";
15         numString = sortNumberString(numString);
16         System.out.println("nums="+numString);
17 
18     }
19 
20     public static String sortNumberString(String numString) {
21         //1一个字符串通过分割变成多个字符串。split();
22         String[] strs = numString.split(" ");
23         
24         //2,不能直接对字符串大小排序。因为字符串23比字符串9要小。必须转成整数值。
25         //将字符串数组转成int[] 数组。
26         int[] nums = parseIntArray(strs);
27         
28         //3,对数组排序。
29         Arrays.sort(nums);
30         
31 //        4,将数组转成字符串。
32         return toString(nums);
33     }
34     private static String toString(int[] nums) {
35         StringBuilder sb  = new StringBuilder();
36         for (int i = 0; i < nums.length; i++) {
37             if(i!=nums.length-1){
38                 sb.append(nums[i]+" ");
39             }else{
40                 sb.append(nums[i]);
41             }
42         }
43         return sb.toString();
44     }
45 
46     //将字符串数组转成int[] 数组
47     public static int[] parseIntArray(String[] strs) {
48         //定义一个int数组。
49         int[] arr = new int[strs.length];
50         
51         //2,遍历字符串数组。把元素转成int存储到int数组中。
52         for (int i = 0; i < strs.length; i++) {
53             arr[i] = Integer.parseInt(strs[i]);
54         }
55         return arr;
56     }
57 
58 }

 

posted on 2016-04-23 12:51  太自由  阅读(373)  评论(0编辑  收藏  举报