自学篇-String类(十二)



一:字符串操作方法

/*


String类适用于描述字符串事物。
那么它就提供了多个方法对字符串进行操作。

常见的操作有哪些?
"abcd"

1,获取。
    1.1 字符串中的包含的字符数,也就是字符串的长度。
        int length():获取长度。
    1.2 根据位置获取位置上某个字符。
        char charAt(int index):
    1.3 根据字符获取该字符在字符串中位置。
        int indexOf(int ch):返回的是ch在字符串中第一次出现的位置。
        int indexOf(int ch, int fromIndex) :从fromIndex指定位置开始,获取ch在字符串中出现的位置。

        int indexOf(String str):返回的是str在字符串中第一次出现的位置。
        int indexOf(String str, int fromIndex) :从fromIndex指定位置开始,获取str在字符串中出现的位置。

        int lastIndexOf(int ch) :

        
2,判断。
    2.1 字符串中是否包含某一个子串。
        boolean contains(str):
        特殊之处:indexOf(str):可以索引str第一次出现位置,如果返回-1.表示该str不在字符串中存在。
                所以,也可以用于对指定判断是否包含。
                if(str.indexOf("aa")!=-1)

                而且该方法即可以判断,有可以获取出现的位置。

    2.2 字符中是否有内容。
        boolean isEmpty(): 原理就是判断长度是否为0.
    2.3 字符串是否是以指定内容开头。
        boolean startsWith(str);
    2.4 字符串是否是以指定内容结尾。
        boolean endsWith(str);
    2.5 判断字符串内容是否相同。复写了Object类中的equals方法。
        boolean equals(str);
    2.6 判断内容是否相同,并忽略大小写。
        boolean equalsIgnoreCase();
    
3,转换。
    3.1 将字符数组转成字符串。
        构造函数:String(char[])
                  String(char[],offset,count):将字符数组中的一部分转成字符串。

        静态方法:
                static String copyValueOf(char[]);
                static String copyValueOf(char[] data, int offset, int count)

                static String valueOf(char[]):

        
    3.2 将字符串转成字符数组。**
        char[] toCharArray():

    3.3 将字节数组转成字符串。
            String(byte[])
            String(byte[],offset,count):将字节数组中的一部分转成字符串。

    3.4 将字符串转成字节数组。
            byte[]  getBytes():
    3.5 将基本数据类型转成字符串。
        static String valueOf(int)
        static String valueOf(double)

        //3+"";//String.valueOf(3);

        特殊:字符串和字节数组在转换过程中,是可以指定编码表的。

4,替换
    String replace(oldchar,newchar);

5,切割
    String[] split(regex);

6,子串。获取字符串中的一部分。
    String substring(begin);
    String substring(begin,end);

7,转换,去除空格,比较。
    7.1 将字符串转成大写或则小写。
         String toUpperCase();
         String toLowerCase();

    7.2 将字符串两端的多个空格去除。
        String trim();

    7.3 对两个字符串进行自然顺序的比较。
        int compareTo(string);


*/

class  StringMethodDemo
{

    public static void method_7()
    {
        String s = "    Hello Java     ";
        sop(s.toLowerCase());
        sop(s.toUpperCase());
        sop(s.trim());

        String s1 = "a1c";
        String s2 = "aaa";

        sop(s1.compareTo(s2));
    }
    public static void method_sub()
    {
        String s = "abcdef";

        sop(s.substring(2));//从指定位置开始到结尾。如果角标不存在,会出现字符串角标越界异常。
        sop(s.substring(2,4));//包含头,不包含尾。s.substring(0,s.length());
    }

    public static void  method_split()
    {
        String s = "zhagnsa,lisi,wangwu";

        String[] arr  = s.split(",");

        for(int x = 0; x<arr.length; x++)
        {
            sop(arr[x]);
        }
    }

    public static void method_replace()
    {
        String s = "hello java";

        //String s1 = s.replace('q','n');//如果要替换的字符不存在,返回的还是原串。


        String s1 = s.replace("java","world");
        sop("s="+s);
        sop("s1="+s1);
    }

    public static void method_trans()
    {
        char[] arr = {'a','b','c','d','e','f'};

        String s= new String(arr,1,3);

        sop("s="+s);

        String s1 = "zxcvbnm";

        char[] chs = s1.toCharArray();

        for(int x=0; x<chs.length; x++)
        {
            sop("ch="+chs[x]);
        }
    }
    public static void method_is()
    {
        String str = "ArrayDemo.java";
        
        //判断文件名称是否是Array单词开头。
        sop(str.startsWith("Array"));
        //判断文件名称是否是.java的文件。
        sop(str.endsWith(".java"));
        //判断文件中是否包含Demo
        sop(str.contains(".java"));


    }


    public static void method_get()
    {
        String str = "abcdeakpf";

        //长度
        sop(str.length());

        //根据索引获取字符。
        sop(str.charAt(4));//当访问到字符串中不存在的角标时会发生StringIndexOutOfBoundsException。


        //根据字符获取索引
        sop(str.indexOf('m',3));//如果没有找到,返回-1.
        
        //反向索引一个字符出现位置。
        sop(str.lastIndexOf("a"));

        
    }
    public static void main(String[] args)
    {
        method_7();
//        method_trans();
//        method_is();
//        method_get();
        /*
        String s1 = "abc";
        String s2 = new String("abc");

        String s3 = "abc";
        System.out.println(s1==s2);
        System.out.println(s1==s3);

        */
    }

    public static void sop(Object obj)
    {
        System.out.println(obj);
    }


}

二:字符串练习:

/*
1,模拟一个trim方法,去除字符串两端的空格。
    思路:
    1,判断字符串第一个位置是否是空格,如果是继续向下判断,直到不是空格为止。
        结尾处判断空格也是如此。
    2,当开始和结尾都判断到不是空格时,就是要获取的字符串。



2,将一个字符串进行反转。将字符串中指定部分进行反转,"abcdefg";abfedcg
    思路:
    1,曾经学习过对数组的元素进行反转。
    2,将字符串变成数组,对数组反转。
    3,将反转后的数组变成字符串。
    4,只要将或反转的部分的开始和结束位置作为参数传递即可。


*/

class StringTest
{

    public static void sop(String str)
    {
        System.out.println(str);
    }
    public static void main(String[] args)
    {
        String s = "      ab cd      ";

        sop("("+s+")");
//        s = myTrim(s);
//        sop("("+s+")");

        sop("("+reverseString(s)+")");
        
    }


    //练习二:将字符串反转。
    /*
    思路:
    1,将字符串变成数组。
    2,对数组反转。
    3,将数组变成字符串。
    */

    public static String reverseString(String s,int start,int end)
    {
        //字符串变数组。
        char[] chs = s.toCharArray();

        //反转数组。
        reverse(chs,start,end);

        //将数组变成字符串。
        return new String(chs);
    }
    public static String reverseString(String s)
    {
        return reverseString(s,0,s.length());
        
    }

    private static void reverse(char[] arr,int x,int y)
    {
        for(int start=x,end=y-1; start<end ; start++,end--)
        {
            swap(arr,start,end);
        }
    }
    private static void swap(char[] arr,int x,int y)
    {
        char temp = arr[x];
        arr[x] = arr[y];
        arr[y] = temp;
    }

    //练习一,去除字符串两端空格。
    public static String myTrim(String str)
    {
        int start = 0,end = str.length()-1;

        while(start<=end && str.charAt(start)==' ')
            start++;

        while(start<=end && str.charAt(end)==' ')
            end--;

        return str.substring(start,end+1);
    }
}

/*
3,获取一个字符串在另一个字符串中出现的次数。
    "abkkcdkkefkkskk"


    思路:
    1,定义个计数器。
    2,获取kk第一次出现的位置。
    3,从第一次出现位置后剩余的字符串中继续获取kk出现的位置。
        每获取一次就计数一次。
    4,当获取不到时,计数完成。



*/

class  StringTest2
{

    /*
    练习三。

    */
    
    public static int getSubCount(String str,String key)
    {
        int count = 0;
        int index = 0;

        while((index=str.indexOf(key))!=-1)
        {
            sop("str="+str);
            str = str.substring(index+key.length());

            count++;    
        }
        return count;
    }

    /*
    练习三,方式二。

    */
    public static int getSubCount_2(String str,String key)
    {
        int count = 0;
        int index = 0;

        while((index= str.indexOf(key,index))!=-1)
        {
            sop("index="+index);
            index = index + key.length();

            count++;
        }
        return count;
    }

    public static void main(String[] args)
    {
        String str = "kkabkkcdkkefkks";

        ///sop("count====="+str.split("kk").length);不建议使用。

        sop("count="+getSubCount_2(str,"kk"));
    }

    public static void sop(String str)
    {
        System.out.println(str);
    }
}


/*
4,获取两个字符串中最大相同子串。第一个动作:将短的那个串进行长度一次递减的子串打印。
    "abcwerthelloyuiodef"
    "cvhellobnm"
    思路:
        1,将短的那个子串按照长度递减的方式获取到。
        2,将每获取到的子串去长串中判断是否包含,
            如果包含,已经找到!。
*/

class  StringTest3
{
    /*
    练习四。
    */
    public static String getMaxSubString(String s1,String s2)
    {

        String max = "",min = "";

        max = (s1.length()>s2.length())?s1: s2;

        min = (max==s1)?s2: s1;
        
//        sop("max="+max+"...min="+min);
        for(int x=0; x<min.length(); x++)
        {
            for(int y=0,z=min.length()-x; z!=min.length()+1; y++,z++)
            {
                String temp = min.substring(y,z);
                
                sop(temp);
                if(max.contains(temp))//if(s1.indexOf(temp)!=-1)
                    return temp;
            }
        }
        return "";
    }


    public static void main(String[] args)
    {
        String s1 = "ab";
        String s2 = "cvhellobnm";
        sop(getMaxSubString(s2,s1));
    }

    public static void sop(String str)
    {
        System.out.println(str);
    }
}


/*
对字符串中字符进行自然顺序排序。

思路:
1,字符串变成字符数组。
2,对数组排序,选择,冒泡,Arrays.sort();
3,将排序后的数组变成字符串。



"vcz1bdAa+cs"-->abccdsvz




作业:
"12 0 99 -7 30 4 100 13"
要求对字符串中的数值进行排序。生成一个数值从小到大新字符串。

"-7 0 4 12 13 30 99 100"


*/


class  
{
    public static void main(String[] args)
    {
        System.out.println("Hello World!");
    }
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值