java-----String类方法应用练习题(getBytes())

该博客介绍了如何在Java中处理GBK编码的字符串,根据指定的字节数进行截取,并避免截取导致的乱码问题。通过判断截取的最后一个字符是否完整,决定是否需要调整截取长度,确保输出正确。

    // 练习:输入一个字符串和一个数字,数字表示字节的个数,按照指定的字节个数截取字符串(GBK)

    例如输入: 世界abc     输入3 出现世

                输入 4 出现 世界 

                输入5 出现 世界a

public class Practice03 {
    public static void main(String[] args) throws UnsupportedEncodingException {
 
        // 获取字符串和字节个数
        Scanner sc = new Scanner(System.in);
        String str = sc.nextLine();
        int n = sc.nextInt();
        // 先将字符串转换为字节数组
        byte[] bs = str.getBytes("gbk");
        // 判断要截取的字节个数是否合法
        if (n <0 || n > bs.length){
            return;
        }
        // 按照指定的字节个数进行截取
        String sub = new String(bs,0,n,"gbk");
        // 判断是否截取了半个字符
        int index = sub.length() - 1;
        if (sub.charAt(index) != str.charAt(index)){
            sub = new String(bs,0,n - 1,"gbk");
        }
        System.out.println(sub);
    }
}

要明白,gbk编码格式是一个汉子2个字节,所以如果是两个汉字那么输入3时就会有乱码的出现,此时需要判断是否截取了半个字符,即将你已经截取好的字符串sub的最后一以为(sub.length-1)与输入的字符串str的最后一位(sub.length-1)判断是不是相同的,若是,则直接输出,若不是,则需要将截取的字符串长度减一(n-1)后进行输出。

### L1-061 Java 习题解决方案 #### 题目描述 假设题目 **L1-061** 是关于字符串处理或者数组操作的一道典型编程问题。基于已知引用的内容,可以推测该类问题可能涉及字符编码转换、字节流操作以及字符串重建等内容。 以下是针对此类问题的一个通用解决方法--- #### 解决方案分析 通过给定的引用内容[^1]可以看出,Java 中可以通过 `String` 类的方法实现字符串到字节数组的转换,并进一步完成数据打印或重新构建的操作。具体来说,代码片段展示了如何利用 `getBytes()` 方法获取字符串对应的字节数组并逐一遍历输出其 ASCII 值。 对于更复杂的场景(如引用中的字符串排列问题[^2]),通常需要考虑以下几点: - 字符串长度范围:`1 <= s1.length, s2.length <= 10^4` - 输入约束条件:仅包含小写字母 - 时间复杂度优化需求:需满足时间限制 (≤ 200ms) 因此,在设计解决方案时应优先选用高效的数据结构和算法来降低计算开销。 另外,从另一个角度出发——即座位安排逻辑[^3]来看待此问题,则可能是要求按照特定规则分配资源或将对象映射至指定位置上;此时则需要注意输入规模限制等因素的影响。 综上所述,下面提供了一个综合上述要点后的参考解答程序如下所示: --- #### 参考代码示例 ```java import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); // 获取输入字符串 String inputStr = scanner.nextLine(); // 将字符串转为字节数组 byte[] byteArray = inputStr.getBytes(); // 输出每个字节及其对应ASCII码值 StringBuilder asciiOutput = new StringBuilder(); for (byte b : byteArray) { asciiOutput.append((int)b).append(" "); } System.out.println(asciiOutput.toString().trim()); // 根据字节数组还原原始字符串 String restoredStr = new String(byteArray); System.out.println(restoredStr); scanner.close(); } } ``` 以上代码实现了基本功能模块,包括但不限于读取用户输入、执行必要的转化过程以及最终结果展示等功能点。 --- #### 进一步思考方向 如果目标扩展到更加广泛的领域比如组合数学方面的话,则还需要引入额外的技术手段来进行深入探讨研究才行。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值