zoukankan      html  css  js  c++  java
  • Java 经典练习题_Day010

     

     

     final 变量能被显式地初始化并且只能初始化一次。被声明为 final 的对象的引用不能指向不同的对象。但是 final 对象里的数据可以被改变。也就是说 final 对象的引用不能改变,但是里面的值可以改变。

     

    一个可变的字符序列。此类提供一个与 StringBuffer 兼容的 API,但不保证同步。该类被设计用作 StringBuffer 的一个简易替换,用在字符串缓冲区被单个线程使用的时候(这种情况很普遍)。如果可能,建议优先采用该类,因为在大多数实现中,它比 StringBuffer 要快。

    StringBuilder 上的主要操作是 appendinsert 方法,可重载这些方法,以接受任意类型的数据。每个方法都能有效地将给定的数据转换成字符串,然后将该字符串的字符追加或插入到字符串生成器中。append 方法始终将这些字符添加到生成器的末端;而 insert 方法则在指定的点添加字符。

    例如,如果 z 引用一个当前内容为 "start" 的字符串的生成器对象,则该方法调用 z.append("le") 将使字符串生成器包含 "startle",而 z.insert(4, "le") 将更改字符串生成器,使之包含 "starlet"。

    通常,如果 sb 引用 StringBuilder 的实例,则 sb.append(x)sb.insert(sb.length(), x) 具有相同的效果。每个字符串生成器都有一定的容量。只要字符串生成器所包含的字符序列的长度没有超出此容量,就无需分配新的内部缓冲区。如果内部缓冲区溢出,则此容量自动增大。

    StringBuilder 的实例用于多个线程是不安全的。如果需要这样的同步,则建议使用 StringBuffer

     

     

     

     

     

    public class Test3_1 {
        public static void main(String[] args) {
            Scanner s = new Scanner(System.in);
            String str = s.next();
            
            Cut(str);
        }
        
        public static void Cut(String str) {
            int len = str.length();
            
            // 长度小于8时
            if(len < 8) {
                System.out.print(str);
                for(int i = 0; i < 8-len; i++) {
                    System.out.print("0");
                }
            }
            // 长度大于8时
            else if(len > 8) {
                String s1 = str.substring(0, 8);
                System.out.println(s1);
                
                String s2 = str.substring(8, len);
                Cut(s2);
                
            }
        }
    }

    import java.util.Arrays;
    
    public class Test3_2 {
        public static void main(String[] args) {
            String str = "gjasdf892534jhkerg";
            
            // \D 匹配所有的非数字
            str = str.replaceAll("\D", "");
            // 字符串转字符数组
            char[] ch = str.toCharArray();
            // 排序
            Arrays.sort(ch);
            
            System.out.println(ch);
        }
    }

     

  • 相关阅读:
    347. 前 K 个高频元素(桶排序、堆排序)
    322. 零钱兑换 && 416. 分割等和子集(0-1背包问题)
    739. 每日温度 && 503. 下一个更大元素 II (单调栈)
    1110. 删点成林
    个人纪录
    pub get failed (server unavailable) -- attempting retry 1 in 1 second?
    python 遍历文件夹重命名
    flutter vscode 连接iphone失败
    部署以太坊合约
    Web漏洞扫描工具AppScan10介绍
  • 原文地址:https://www.cnblogs.com/chuijingjing/p/9524835.html
Copyright © 2011-2022 走看看