题解 | #二进制插入#

二进制插入

http://www.nowcoder.com/questionTerminal/30c1674ad5694b3f8f0bc2de6f005490

二进制插入

二进制插入

/*
2022年09月21日 11:43:09
m插到n
00010011
010000000000
插入到19的第2~6位
010001001100
注意,先倒着插,最后才能reverse回来
需要完全覆盖掉m
*/
class BinInsert {
public:
    int binInsert(int n, int m, int j, int i) {
        string strn, strm;
        while(n){
            if(n % 2 == 1) // 最后一位为1
                strn += '1';
            else
                strn += '0';
            n /= 2;
        } // "11001000"
        while(m){
            if(m % 2 == 1) // 最后一位为1
                strm += '1';
            else
                strm += '0';
            m /= 2;
        } // "00000000001"
        strn.replace(j, strm.size(), strm); // "00110010001"  覆盖的长度得是m的长度
        reverse(strn.begin(), strn.end()); // "10001001100"
        int ret = stoi(strn, nullptr, 2); // 需要转换成2进制
        return ret;
    }
};
/*
2022年09月21日 11:43:09
010000000000
       10011
插入到2~6位
010000000000
     10011
m左移j位,再和n或一下就行
010001001100
*/
class BinInsert {
public:
    int binInsert(int n, int m, int j, int i) {
        return n | (m << j);
    }
};
全部评论

相关推荐

02-11 17:51
腾讯_TEG_技术
点赞 评论 收藏
分享
01-02 00:50
三峡大学 Java
程序员牛肉:这简历一出手就离失业不远了。 作为一家公司来讲,我如果要招日常实习生,那我对实习生最基本的要求就是要能干活,毕竟你就待三四个月,谁会留心培养你? 那么除了院校之外,最重要的就是项目和实习了。没有实习的话项目就好好搞。 但是你说你这个项目吧:课程作业管理系统和TMS运输管理系统。这两个基本就和闹着玩差不多。 你作为一个想要应聘Java开发实习生的人,对后端的理解还仅仅停留在:“使用mapper和sql映射”,“使用SQL进行多表调用”,“基于MySQL简历表结构”,“基于Spring boot完成CURD操作”这种玩具上......... 找不到后端实习的
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务