字符串的处理
很久前就像写个博客,来记录一下自己的成长,今天是2017.5.5 18:40,记录一下这个伟大的时刻,因为我终于开通了自己的博客,很开心的。。。好啦言归正传,讲讲自己今天想记录的内容,昨天晚上经理给我出了这样一个题目,因为是新人吧,所以题目不难,有点想考研本小白的意味(还好本小白会),让我做一个数据的处理,就是比如 十进制的5,转化成2进制 就是 0101;然后变成0111;也就是十进制的7,然后再把7变成5.也就是指定一位数,然后把它指定的第几位变成0或者1;今天有时间本小白随手写了一下,还是很简单的,我用的开发工具就是vs,开发平台win7,代码如下
int deal(int n,int m)//指定位置致一 { int a; a = n | 0x1<<m-1; return a; } int deal1(int n,int m)//指定位置制成0 { int a; a = n & ~(0x1<<m-1); return a; }
1.为啥是m-1而不是m呢。。。。。。。。。。。。。。。。因为0x1 那个1也占一位啊,对吧,所以要减一。。。。
2.为啥制成0的时候要这样写呢,0x1 也就是 0001左移一位 变成0010;然后取个反 变成 1101,第二位不就变成0,然后与一下 不就成0了。。。。然与后看看其他的位,跟1与的话,原来要是1,是不变的。原来要是0,也是不变的,所以不改变别的位的数值(也就是0或者1),所以只改变的固定的数值的