题解 | #字符串合并处理#

字符串合并处理

http://www.nowcoder.com/practice/d3d8e23870584782b3dd48f26cb39c8f

import java.util.; import java.io.;

public class Main{

 public static void main(String[] args){

    InputStreamReader reader =  new InputStreamReader(System.in);
    try(BufferedReader br = new BufferedReader(reader)){

        String[] strs = br.readLine().split(" ");
        String str_concat =  strs[0].concat(strs[1]);

        StringBuffer sb_odd =  new StringBuffer();
        StringBuffer sb_even =  new StringBuffer();
        StringBuffer sb_result =  new StringBuffer();


        for(int i=0;i<str_concat.length();i++){

            if(i%2==0)
                sb_odd.append(str_concat,i,i+1);
            else
                sb_even.append(str_concat,i,i+1);
        }

        String str_odd = sb_odd.toString();
        String str_even = sb_even.toString();

        str_odd = sort(str_odd.toCharArray());
        str_even = sort(str_even.toCharArray());


        // 奇数位最少等于偶数位
        for (int i =0; i <str_odd.length(); i++) {


            sb_result.append(str_odd, i, i+1);

            if ((i == str_odd.length()-1) && str_odd.length() > sb_even.length()) continue;

            sb_result.append(str_even, i, i+1);

        }
        System.out.println(translate(sb_result.toString().toCharArray()));



    }catch(IOException e){
        System.out.println(e.getMessage());
    }
}

public static String sort(char[] chars){

    char tmp = ' ';
    for (int i = 0; i < chars.length-1; i++) {
        for (int j = 0; j < chars.length-1; j++) {

            if (chars[j]>chars[j+1]){
                tmp = chars[j+1];
                chars[j+1]=chars[j];
                chars[j] = tmp;
            }

        }
    }

    return String.valueOf(chars);

}

public static String translate(char[] chars){


    StringBuffer buffer_result = new StringBuffer();
    for (int i = 0; i < chars.length; i++) {

        StringBuffer buffer = new StringBuffer();
        int digit = 0;
        if (Character.isLetter(chars[i])){
            //不是 十六进制字母
            if (Character.toLowerCase(chars[i]) > 'f' ||Character.toLowerCase(chars[i])< 'a' ){
                buffer_result.append(chars[i]);
                continue;
            }
             digit = Character.digit(chars[i], 16);
        }

        if (Character.isDigit(chars[i])){
             digit = Character.digit(chars[i], 10);
        }

        String binaryString = Integer.toBinaryString(digit);

        while (binaryString.length()!=4){
            binaryString = "0"+binaryString;
        }

        StringBuffer reverse_binaryString = buffer.append(binaryString).reverse();

        int reverse_value = Integer.parseInt(reverse_binaryString.toString(), 2);

        if (reverse_value<=9){
            buffer_result.append(reverse_value);
        }else {
            char tmp = ' ';
            switch (reverse_value) {
                case 10: tmp = 'A';
                break;
                case 11: tmp = 'B';
                    break;
                case 12: tmp = 'C';
                    break;
                case 13: tmp = 'D';
                    break;
                case 14: tmp = 'E';
                    break;
                case 15: tmp = 'F';
                    break;
            }
            buffer_result.append(tmp);
        }
    }
return buffer_result.toString();
}

}

全部评论

相关推荐

昨天 10:23
已编辑
湖南师范大学 计调
太久没更新,前几天看到一条评论,说“牛客就是当年那群做题区毕业了开始找工作还收不住那股味”的群体。字里行间透着居高临下的评判,不是,他该不会以为自己很幽默?很犀利吧?作为在牛客混了不算短日子的用户,我感到的不只是被冒犯,更是一种深刻的悲哀——这种以“松弛感”为名,对另一种生存策略的轻蔑,颇有一种自己考不上大学早早出来混社会,嘲笑考上大学的人是书呆子,然后大言不惭地说:死读书有什么用,人脉和资源才是硬道理。我不知道说这个话的人,手头究竟握着多少真正管用的人脉与资源,也不知道他这么傲慢地说出“那股味”的时候,是站在哪一个巨人的肩膀上,才能如此“松弛从容”地俯视众生,还能品评出别人身上“没收住”的余...
淬月星辉:这种评论把正常的努力扭曲成卷😂,说白了就是自己不努力,看着身边努力的人一个个都事业有成了,自己的心里开始不平衡了,就发这种酸言酸语。牛客可以说是我用过那么多平台里社区氛围最好的论坛了,用了大半年了,基本上没见过有人吵架的,都是在互帮互助提建议,帮忙看简历的,帮忙选offer的,帮忙指点学习路线的,分享工作经验和趣事的,我觉得这才是互联网该有的样子。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务