常用类-Sting类案例练习

1.String类判断功能

/*
 * 模拟登录,给三次机会,并提示还有几次。如果登录成功,就可以玩猜数字小游戏了。
 * 
 * 分析:
 *      A:定义用户名和密码。已存在的。
 *      B:键盘录入用户名和密码。
 *      C:比较用户名和密码。
 *          如果都相同,则登录成功
 *          如果有一个不同,则登录失败
 *      D:给三次机会,用循环改进,最好用for循环。
 */
public class StringTest2 {
    public static void main(String[] args) {
        // 定义用户名和密码。已存在的。
        String username = "admin";
        String password = "admin";

        // 给三次机会,用循环改进,最好用for循环。
        for (int x = 0; x < 3; x++) {
            // x=0,1,2
            // 键盘录入用户名和密码。
            Scanner sc = new Scanner(System.in);
            System.out.println("请输入用户名:");
            String name = sc.nextLine();
            System.out.println("请输入密码:");
            String pwd = sc.nextLine();

            // 比较用户名和密码。
            if (name.equals(username) && pwd.equals(password)) {
                // 如果都相同,则登录成功
                System.out.println("登录成功,开始玩游戏");
                //猜数字游戏
                GuessNumberGame.start();
                break;
            } else {
                // 如果有一个不同,则登录失败
                // 2,1,0
                // 如果是第0次,应该换一种提示
                if ((2 - x) == 0) {
                    System.out.println("帐号被锁定,请与所长联系");
                } else {
                    System.out.println("登录失败,你还有" + (2 - x) + "次机会");
                }
            }
        }
    }
}

2.String类的获取功能

/*
 * 需求:统计一个字符串中大写字母字符,小写字母字符,数字字符出现的次数。(不考虑其他字符)
 * 举例:
 *      "Hello123World"
 * 结果:
 *      大写字符:2个
 *      小写字符:8个
 *      数字字符:3个
 * 
 * 分析:
 *      前提:字符串要存在
 *      A:定义三个统计变量
 *          bigCount=0
 *          smallCount=0
 *          numberCount=0
 *      B:遍历字符串,得到每一个字符。
 *          length()和charAt()结合
 *      C:判断该字符到底是属于那种类型的
 *          大:bigCount++
 *          小:smallCount++
 *          数字:numberCount++
 * 
 *          这道题目的难点就是如何判断某个字符是大的,还是小的,还是数字的。
 *          ASCII码表:
 *              0   48
 *              A   65
 *              a   97
 *          虽然,我们按照数字的这种比较是可以的,但是想多了,有比这还简单的
 *              char ch = s.charAt(x);
 * 
 *              if(ch>='0' && ch<='9') numberCount++
 *              if(ch>='a' && ch<='z') smallCount++
 *              if(ch>='A' && ch<='Z') bigCount++
 *      D:输出结果。
 *
 * 练习:把给定字符串的方式,改进为键盘录入字符串的方式。
 */
public class StringTest2 {
    public static void main(String[] args) {
        //定义一个字符串
        String s = "Hello123World";

        //定义三个统计变量
        int bigCount = 0;
        int smallCount = 0;
        int numberCount = 0;

        //遍历字符串,得到每一个字符。
        for(int x=0; x<s.length(); x++){
            char ch = s.charAt(x);

            //判断该字符到底是属于那种类型的
            if(ch>='a' && ch<='z'){
                smallCount++;
            }else if(ch>='A' && ch<='Z'){
                bigCount++;
            }else if(ch>='0' && ch<='9'){
                numberCount++;
            }
        }

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

3.String的转换功能

/*
 * 需求:把一个字符串的首字母转成大写,其余为小写。(只考虑英文大小写字母字符)
 * 举例:
 *      helloWORLD
 * 结果:
 *      Helloworld
 * 
 * 分析:
 *      A:先获取第一个字符
 *      B:获取除了第一个字符以外的字符
 *      C:把A转成大写
 *      D:把B转成小写
 *      E:C拼接D
 */
public class StringTest {
    public static void main(String[] args) {
        // 定义一个字符串
        String s = "helloWORLD";

        // 先获取第一个字符
        String s1 = s.substring(0, 1);
        // 获取除了第一个字符以外的字符
        String s2 = s.substring(1);
        // 把A转成大写
        String s3 = s1.toUpperCase();
        // 把B转成小写
        String s4 = s2.toLowerCase();
        // C拼接D
        String s5 = s3.concat(s4);
        System.out.println(s5);

        // 优化后的代码
        // 链式编程
        String result = s.substring(0, 1).toUpperCase()
                .concat(s.substring(1).toLowerCase());
        System.out.println(result);
    }
}

案例练习

/*
 * 需求:把数组中的数据按照指定个格式拼接成一个字符串
 * 举例:
 *      int[] arr = {1,2,3};    
 * 输出结果:
 *      "[1, 2, 3]"
 * 分析:
 *      A:定义一个字符串对象,只不过内容为空
 *      B:先把字符串拼接一个"["
 *      C:遍历int数组,得到每一个元素
 *      D:先判断该元素是否为最后一个
 *          是:就直接拼接元素和"]"
 *          不是:就拼接元素和逗号以及空格
 *      E:输出拼接后的字符串
 */
public class StringTest {
    public static void main(String[] args) {
        // 前提是数组已经存在
        int[] arr = { 1, 2, 3 };

        // 定义一个字符串对象,只不过内容为空
        String s = "";

        // 先把字符串拼接一个"["
        s += "[";

        // 遍历int数组,得到每一个元素
        for (int x = 0; x < arr.length; x++) {
            // 先判断该元素是否为最后一个
            if (x == arr.length - 1) {
                // 就直接拼接元素和"]"
                s += arr[x];
                s += "]";
            } else {
                // 就拼接元素和逗号以及空格
                s += arr[x];
                s += ", ";
            }
        }

        // 输出拼接后的字符串
        System.out.println("最终的字符串是:" + s);
    }
}
/*
 * 需求:把数组中的数据按照指定个格式拼接成一个字符串
 * 举例:
 *      int[] arr = {1,2,3};    
 * 输出结果:
 *      "[1, 2, 3]"
 * 分析:
 *      A:定义一个字符串对象,只不过内容为空
 *      B:先把字符串拼接一个"["
 *      C:遍历int数组,得到每一个元素
 *      D:先判断该元素是否为最后一个
 *          是:就直接拼接元素和"]"
 *          不是:就拼接元素和逗号以及空格
 *      E:输出拼接后的字符串
 * 
 * 把代码用功能实现。
 */
public class StringTest2 {
    public static void main(String[] args) {
        // 前提是数组已经存在
        int[] arr = { 1, 2, 3 };

        // 写一个功能,实现结果
        String result = arrayToString(arr);
        System.out.println("最终结果是:" + result);
    }

    /*
     * 两个明确: 返回值类型:String 参数列表:int[] arr
     */
    public static String arrayToString(int[] arr) {
        // 定义一个字符串
        String s = "";

        // 先把字符串拼接一个"["
        s += "[";

        // 遍历int数组,得到每一个元素
        for (int x = 0; x < arr.length; x++) {
            // 先判断该元素是否为最后一个
            if (x == arr.length - 1) {
                // 就直接拼接元素和"]"
                s += arr[x];
                s += "]";
            } else {
                // 就拼接元素和逗号以及空格
                s += arr[x];
                s += ", ";
            }
        }

        return s;
    }
}
/*
 * 字符串反转
 * 举例:键盘录入”abc”     
 * 输出结果:”cba”
 * 
 * 分析:
 *      A:键盘录入一个字符串
 *      B:定义一个新字符串
 *      C:倒着遍历字符串,得到每一个字符
 *          a:length()和charAt()结合
 *          b:把字符串转成字符数组
 *      D:用新字符串把每一个字符拼接起来
 *      E:输出新串
 */
public class StringTest3 {
    public static void main(String[] args) {
        // 键盘录入一个字符串
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入一个字符串:");
        String line = sc.nextLine();

        /*
        // 定义一个新字符串
        String result = "";

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

        // 倒着遍历字符串,得到每一个字符
        for (int x = chs.length - 1; x >= 0; x--) {
            // 用新字符串把每一个字符拼接起来
            result += chs[x];
        }

        // 输出新串
        System.out.println("反转后的结果是:" + result);
        */

        // 改进为功能实现
        String s = myReverse(line);
        System.out.println("实现功能后的结果是:" + s);
    }

    /*
     * 两个明确: 返回值类型:String 参数列表:String
     */
    public static String myReverse(String s) {
        // 定义一个新字符串
        String result = "";

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

        // 倒着遍历字符串,得到每一个字符
        for (int x = chs.length - 1; x >= 0; x--) {
            // 用新字符串把每一个字符拼接起来
            result += chs[x];
        }
        return result;
    }
}
/*
 * 统计大串中小串出现的次数
 * 举例:
 *      在字符串"woaijavawozhenaijavawozhendeaijavawozhendehenaijavaxinbuxinwoaijavagun"
 * 结果:
 *      java出现了5次
 * 
 * 分析:
 *      前提:是已经知道了大串和小串。
 * 
 *      A:定义一个统计变量,初始化值是0
 *      B:先在大串中查找一次小串第一次出现的位置
 *          a:索引是-1,说明不存在了,就返回统计变量
 *          b:索引不是-1,说明存在,统计变量++
 *      C:把刚才的索引+小串的长度作为开始位置截取上一次的大串,返回一个新的字符串,并把该字符串的值重新赋值给大串
 *      D:回到B
 */
public class StringTest4 {
    public static void main(String[] args) {
        // 定义大串
        String maxString = "woaijavawozhenaijavawozhendeaijavawozhendehenaijavaxinbuxinwoaijavagun";
        // 定义小串
        String minString = "java";

        // 写功能实现
        int count = getCount(maxString, minString);
        System.out.println("Java在大串中出现了:" + count + "次");
    }

    /*
     * 两个明确: 返回值类型:int 参数列表:两个字符串
     */
    public static int getCount(String maxString, String minString) {
        // 定义一个统计变量,初始化值是0
        int count = 0;

        // 先在大串中查找一次小串第一次出现的位置
        int index = maxString.indexOf(minString);

        // 索引不是-1,说明存在,统计变量++
        while (index != -1) {
            count++;
            // 把刚才的索引+小串的长度作为开始位置截取上一次的大串,返回一个新的字符串,并把该字符串的值重新赋值给大串
            int startIndex = index + minString.length();
            maxString = maxString.substring(startIndex);
            // 继续查
            index = maxString.indexOf(minString);
        }

        return count;
    }
}
/*
 * 统计大串中小串出现的次数
 * 举例:
 *      在字符串"woaijavawozhenaijavawozhendeaijavawozhendehenaijavaxinbuxinwoaijavagun"
 * 结果:
 *      java出现了5次
 * 
 * 分析:
 *      前提:是已经知道了大串和小串。
 * 
 *      A:定义一个统计变量,初始化值是0
 *      B:先在大串中查找一次小串第一次出现的位置
 *          a:索引是-1,说明不存在了,就返回统计变量
 *          b:索引不是-1,说明存在,统计变量++
 *      C:把刚才的索引+小串的长度作为开始位置截取上一次的大串,返回一个新的字符串,并把该字符串的值重新赋值给大串
 *      D:回到B
 */
public class StringTest5 {
    public static void main(String[] args) {
        // 定义大串
        String maxString = "woaijavawozhenaijavawozhendeaijavawozhendehenaijavaxinbuxinwoaijavagun";
        // 定义小串
        String minString = "java";

        // 写功能实现
        int count = getCount(maxString, minString);
        System.out.println("Java在大串中出现了:" + count + "次");
    }

    /*
     * 两个明确: 返回值类型:int 参数列表:两个字符串
     */
    public static int getCount(String maxString, String minString) {
        // 定义一个统计变量,初始化值是0
        int count = 0;

        /*
        // 先在大串中查找一次小串第一次出现的位置
        int index = maxString.indexOf(minString);
        // 索引不是-1,说明存在,统计变量++
        while (index != -1) {
            count++;
            // 把刚才的索引+小串的长度作为开始位置截取上一次的大串,返回一个新的字符串,并把该字符串的值重新赋值给大串
            // int startIndex = index + minString.length();
            // maxString = maxString.substring(startIndex);
            maxString = maxString.substring(index + minString.length());
            // 继续查
            index = maxString.indexOf(minString);
        }
        */

        int index;
        //先查,赋值,判断
        while((index=maxString.indexOf(minString))!=-1){
            count++;
            maxString = maxString.substring(index + minString.length());
        }

        return count;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值