算法小知识-----10.03----- 重新格式化电话号码

172 阅读2分钟

持续创作,加速成长!这是我参与「掘金日新计划 · 10 月更文挑战」的第6天,点击查看活动详情

国庆眨眼便第三天了,简单题,重拳出击

重新格式化电话号码

该题出自力扣的1694题 —— 重新格式化电话号码【简单题】

审题

给你一个字符串形式的电话号码 number 。number 由数字、空格 ' '、和破折号 '-' 组成。 请你按下述方式重新格式化电话号码。 首先,删除 所有的空格和破折号。 其次,将数组从左到右 每 3 个一组 分块,直到 剩下 4 个或更少数字。剩下的数字将按下述规定再分块: 2 个数字:单个含 2 个数字的块。 3 个数字:单个含 3 个数字的块。 4 个数字:两个分别含 2 个数字的块。 最后用破折号将这些块连接起来。注意,重新格式化过程中 不应该 生成仅含 1 个数字的块,并且 最多 生成两个含 2 个数字的块。 返回格式化后的电话号码。

  • 该题虽然题目阐述比较繁琐,但是拆分出来,还是比较容易,毕竟作为简单题
  • 给出一个字符串,内部由数字、空格和破折号“-”组成,首先需要把空格和破折号取出
  • 把字符串整合成完全数字组成以后,再根据规则重新分配破折号
  • 解法:
    • 先通过String的replace截取空格和破折号
    • 分析规则后,3个一组,最后剩下的可能性分别是 4 、3、 2,分别有对应的规则处理
    • 用StringBuilder处理即可
  • 首先对给定的字符串 number 进行一次遍历,找出所有的数字,并记录在字符串 sb 中  

编码

class Solution {
    public String reformatNumber(String number) {
        number = number.replace(" ","").replace("-","");
        int n = number.length();
        int a = n /3;
        int la = n % 3;
        int index = -1;
        StringBuilder sb =new StringBuilder();
        while (a != 0){
            if (a == 1 && la == 1){
                sb.append(number.charAt(++index));
                sb.append(number.charAt(++index));
                sb.append("-");
                sb.append(number.charAt(++index));
                sb.append(number.charAt(++index));
                break;
            }
            sb.append(number.charAt(++index));
            sb.append(number.charAt(++index));
            sb.append(number.charAt(++index));
            sb.append("-");
            a--;
        }
        if (la == 2){
            sb.append(number.charAt(++index));
            sb.append(number.charAt(++index));
        }else if (la == 0){
            sb.deleteCharAt(sb.length() -1);
        }
        return sb.toString();
    }
}

image.png