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

字符串合并处理

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

#include <iostream>
#include <cstring>
#include <sstream>
#include <string>
#include <algorithm>
using namespace std;
int find(string dictory,char ch)
{
    for(int i = 0; i < dictory.size();i++)
    {
        if(ch>='a'&&ch<='z')
        {
            ch = char(ch-32);
        }
        if(ch == dictory[i])
            return i;
    }
    return -1;
}

int main() {
    string str1,str2;
    getline(cin,str1,' ');
    getline(cin,str2, ' ');
    string str = str1+str2;
    stringstream oddss;
    stringstream evenss;
    for(int i = 0; i < str.size();i++)
    {
        if(i%2==0)
            evenss<<str[i];
        else
            oddss<<str[i];
    }
    string even,odd;
    getline(evenss,even);
    getline(oddss, odd);
    sort(even.begin(),even.end());
    sort(odd.begin(),odd.end());
    string strAfterSort = str;
    for(int i = 0,t = 0,j = 0; i < str.size();i++)
    {
        if(i%2==0)
        {
            strAfterSort[i] = even[t];
            t++;
        }
        else 
        {
            strAfterSort[i] = odd[j];
            j++;
        }  
    }

    string dictory = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
    for(int i = 0; i<strAfterSort.size();i++)
    {
        int value = find(dictory,strAfterSort[i]);
        if(value == -1)
            continue;
        if(value > 15)
        {
            cout<<strAfterSort[i];
            continue;
        }
        string binary(4,'0');
        if(value == 0)
            binary = "0000";
        else
        {
            
            if(value == 1)
                binary = "1000";
                else
                 {
                    int count = 0;
                    while(value!=0)
                    {
                        binary[count++] = char(value%2+48);
                        value/=2;
                    }
                 }
            
        }
        int valueTurn = (binary[0]-48)*8+(binary[1]-48)*4+(binary[2]-48)*2+binary[3]-48;
        cout<<dictory[valueTurn];
        

    }
    

    

    
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

2025-12-28 20:47
已编辑
北京工商大学 Java
程序员牛肉:我靠你这个实习经历其实最需要担心的点是你做的太多了,可能会被面试官怀疑是你伪造的。 交易状态机是你做的,支付多渠道是你做的,对账是你做的,结算还是你做的,重复支付也是你做的,整个服务的异常处理也是你做的。 其实你这个反而问题很大的,你想想站在面试官的角度,他是真的会相信你的能力很强,还是相信这份实习你伪造了大部分?我相信你真的做了这么多,但是删一些,废话删一删。你这个做的太多了反而真实性不可信。 后面再补一个项目,在github上找一个高star的项目学一学然后写到自己简历上。我觉得你能力肯定没问题。28届能做到这个份上很厉害,但是在求职市场中,你不是在跟28届的同学比,把你这个简历放到27届其实也就一般水平。 所以后续要想一想看看能不能给自己简历上搞点亮点,比如开源贡献呢?比如博客呢?
实习要如何选择和准备?
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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