博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
一道笔试题:给定编码规则,实现decode()方法
阅读量:6340 次
发布时间:2019-06-22

本文共 1541 字,大约阅读时间需要 5 分钟。

public class CodeDecode {

    /*变换函数encode()顺序考察已知字符串的字符,按以下规则逐组生成新字符串:
      (1)若已知字符串的当前字符不是大于0的数字字符,则复制该字符与新字符串中;
      (2)若以已知字符串的当前字符是一个数字字符,且他之后没有后继字符,则简单地将它复制到新字符串中;
      (3)若以已知字符串的当前字符是一个大于0的数字字符,并且还有后继字符,设该数字字符的面值为n,
         则将它的后继字符(包括后继字符是一个数字字符) 重复复制n+1 次到新字符串中;
      (4)以上述一次变换为一组,在不同组之间另插入一个下划线'_'用于分隔;
      (5)若已知字符串中包含有下划线'_',则变换为用"/UL".*/
    // by fengzh.
    public String decode2(String oldStr) {
        StringBuffer sb = new StringBuffer();
        for(int i=0;i<oldStr.length();i++) {
            char ch = oldStr.charAt(i);
            if(Character.isDigit(ch)){
                if(ch=='0'){
                    sb.append(ch);
                } else {
                    if(i==oldStr.length()-1){
                        sb.append(ch);
                    } else {
                        int n = ch - '0';
                        char nextCh = oldStr.charAt(i+1);
                        for(int j=0;j<n+1;j++){
                            sb.append(nextCh);
                        }
                    }
                }
                if(i!=oldStr.length()-1){
                    sb.append('_');
                }
            } else if(ch=='_') {
                sb.append("/UL");
            } else {
                if(i!=oldStr.length()-1){
                    sb.append(ch);
                    sb.append('_');
                }
            }
        }
        return sb.toString();
    }

    public String pub = "";

    public void decode(String str) {

        if (str.charAt(0) == '_') {
            pub = pub + "//UL";
        } else if ("123456789".indexOf(str.charAt(0)) == -1) {
            pub = pub + str.charAt(0) + "_";
        } else if (str.length() == 1) {
            pub = pub + str;
            return;
        } else {
            for (int i = 0; i < "123456789".indexOf(str.charAt(0)) + 2; i++)
                pub = pub + str.charAt(1);
            pub = pub + "_";
        }
        if (str.length() != 1)
            this.decode(str.substring(1));
    }

    public static void main(String[] args) {

        CodeDecode d = new CodeDecode();
        String oldStr = "24ab_2t2";
        // d.decode("24ab_2t2"); // 结果:444_aaaaa_a_b_//ULttt_t_2
        d.pub = d.decode2(oldStr); // 结果:444_aaaaa_a_b_/ULttt_t_2
        System.out.println(d.pub);
    }
}

转载地址:http://cjhoa.baihongyu.com/

你可能感兴趣的文章
15个开发者最亲睐的Android代码编辑器
查看>>
html web 简单打印
查看>>
Quartz2D打水印
查看>>
分布式事物方案前-BASE理论的介绍
查看>>
在商业项目中使用JDK?
查看>>
Groovy使用List集合
查看>>
PXE自动化安装CentOS 7
查看>>
网络安全与防火墙
查看>>
centos7.2下安装haproxy1.7
查看>>
MySQL/MariaDB DML操作之Select
查看>>
Spring Security 3.1.1安全控制的例子(二)
查看>>
设计模式之-工厂方法
查看>>
python学习笔记---字典
查看>>
activemq Required JARs
查看>>
Oracle --包
查看>>
strace命令_Linux strace 命令用法详解:跟踪系统调用和信号
查看>>
python学习之输入输出,if,while,for,简单的turtle使用
查看>>
Java防盗链在报表中的应用实例
查看>>
输出* *** *****....图形
查看>>
C++实现双向链表
查看>>