一、取反的高级用法

#include<stdio.h>
#include<stdlib.h> //取反的作用:末位清零 取反适用于各种位数不同的数据
void main0(){
unsigned char ch=; //0100 1001
unsigned short sh=; //0100 0000 0000 0001
ch=ch&~;//抹平最后一位
sh=sh&~;
printf("%d,%d\n",ch,sh);
system("pause");
} //求余数,不用求余运算符
void main(){
unsigned char ch=; //0100 1001 求出73被4整除的余数
//首先,将73换为2进制数,然后抹平最后两位(抹平后的数就可以整除4了)
printf("%d\n",ch-(ch&~));// ch&~3 抹平最后两位
system("pause");
}

二、内存(高位在高字节,低位在低字节)

三、补码

#include<stdio.h>
#include<stdlib.h> void main(){
//printf不会进行类型转换
printf("%d\n",10.3);//printf不管是什么类型,按照%d,%f解析数据,不同的解析方式有不同的结果
printf("%f\n",);
printf("%d\n",(int)10.3);
printf("%f\n",(float)); system("pause");
}

char ch=,ch1='';//字符与编号的区别
printf("%d,%d\n",ch,ch1);
system("pause");

#include<stdio.h>
#include<stdlib.h> void main(){
int x=;
int y=-;
//1111 1111 1111 1111 1111 1111 1111 1111 在内存中的存储方式
//无符号,没有符号位,全都是数据 4294967295 //0000 0000 0000 0000 0000 0000 0000 0001 1原码
//1000 0000 0000 0000 0000 0000 0000 0001 -1原码
//1111 1111 1111 1111 1111 1111 1111 1110 -1反码
//1111 1111 1111 1111 1111 1111 1111 1111 -1补码 printf("%d,%u\n",x,x);
printf("%d,%u\n",y,y);
system("pause");
}

unsigned int num=-;
//1111 1111 1111 1111 1111 1111 1111 1111 内存的存储方式
printf("%d,%u\n",num,num);

四、移位(CPU寄存器中进行计算)

1.左移

#include<stdio.h>
#include<stdlib.h> //左移一位等于*2
void main(){
unsigned char ch=; //0000 0001 1
printf("%d\n",ch<<); //0000 0010 2
printf("%d\n",ch<<); //0000 0100 4 // ch<<2 CPU寄存器计算
printf("%d\n",ch); //移位不改变原值
printf("%d\n",ch=(ch<<));//通过赋值号改变原值
system("pause");
}

//左移要注意溢出,考虑数据的极限
void main0(){
unsigned char ch=; //0000 0001 1
//ch=ch<<7; //1000 0000 128
ch=ch<<; //10000 0000 溢出,为0
printf("%d\n",ch); //溢出后的数据无法读取
system("pause");
}

2.右移

#include<stdio.h>
#include<stdlib.h> //右移一位等于÷2
void main(){
unsigned char ch=; //1000 0000
printf("%d\n",ch>>);
printf("%d\n",ch>>);
printf("%d\n",ch);
printf("%d\n",ch=ch>>);
system("pause");
}

五、微软试题

#include<stdio.h>
#include<stdlib.h> void main(){
int x=; //10 0111 0000 1111
int i=;
while (x)
{
i++;
x=x&(x-);//每次操作清零一个“1”,用于统计二进制整数有多少个1
}
printf("%d\n",i);
system("pause");
}

返回值为8

补充:9999如何转为2进制数

[c/c++] programming之路(31)、位运算(二)的更多相关文章

  1. 剑指offer 11. 位运算 二进制中1的个数

    题目描述 输入一个整数,输出该数二进制表示中1的个数.其中负数用补码表示.   //思想:用1(1自身左移运算,其实后来就不是1了)和n的每位进行位与,来判断1的个数     private stat ...

  2. Mysql 查询—按位运算

    前言:虽说这是件小事儿,但本宝宝思前想后,还是为它留下一笔,嘿嘿.反正写博客不浪费纸和笔!好久没有开启我的逗比模式了,我亲爱的乖徒弟DBA,DBB,DBAA等,好久不见你们,遥祝幸福快乐+DB. 整个 ...

  3. zoj--3870--Team Formation(位运算好题)

    Team Formation Time Limit: 3000MS   Memory Limit: 131072KB   64bit IO Format: %lld & %llu Submit ...

  4. [c/c++] programming之路(30)、位运算(一)

    一.取反 ~ #include<stdio.h> #include<stdlib.h> void main(){ unsigned ; //0000 1111 char的单位是 ...

  5. C#中缓存的使用 ajax请求基于restFul的WebApi(post、get、delete、put) 让 .NET 更方便的导入导出 Excel .net core api +swagger(一个简单的入门demo 使用codefirst+mysql) C# 位运算详解 c# 交错数组 c# 数组协变 C# 添加Excel表单控件(Form Controls) C#串口通信程序

    C#中缓存的使用   缓存的概念及优缺点在这里就不多做介绍,主要介绍一下使用的方法. 1.在ASP.NET中页面缓存的使用方法简单,只需要在aspx页的顶部加上一句声明即可:  <%@ Outp ...

  6. Java 位运算2-LeetCode 201 Bitwise AND of Numbers Range

    在Java位运算总结-leetcode题目博文中总结了Java提供的按位运算操作符,今天又碰到LeetCode中一道按位操作的题目 Given a range [m, n] where 0 <= ...

  7. SQL Server时间粒度系列----第8节位运算以及设置日历数据表节假日标志详解

    本文目录列表: 1.位运算 2.设置日历数据表节假日标志 3.总结语 4.参考清单列表   位运算   SQL Server支持的按位运算符有三个,分别为:按位与(&).按位或(|).按位异或 ...

  8. JavaScript 位运算总结&拾遗

    最近补充了一些位运算的知识,深感位运算的博大精深,此文作为这个系列的总结篇,在此回顾下所学的位运算知识和应用,同时也补充下前文中没有提到的一些位运算知识. 把一个数变为大于等于该数的最小的2的幂 一个 ...

  9. javascript 位运算

    位运算博大精深,本文总结下基本的位运算的概念. 1.整数的二进制码 位操作符用于在最基本的层次上,即按内存中表示数值的位来操作数值.ECMAScript中的所有数值都以IEEE-754 64位格式存储 ...

  10. javascript位运算

    javascript作为一门高级语言,他尽量让开发人员减少思考底层的硬件工作原理,而将精力集中在逻辑开发的层面.不过,不论这门语言多么高级,我们必须知道数据依然以bits的形式存储,有时候我们会直接与 ...

随机推荐

  1. go 并发编程(2)

    协程 执行体是个抽象的概念,在操作系统层面有很多个概念与之对应,如操作系统自己掌管的进程(process),进程内的线程(thread),以及进程内的协程(coroutine,也叫轻量级线程).与传统 ...

  2. 弄懂JDK、JRE和JVM到底是什么

    首先是JDK JDK(Java Development Kit) 是 Java 语言的软件开发工具包(SDK).在JDK的安装目录下有一个jre目录,里面有两个文件夹bin和lib,在这里可以认为bi ...

  3. 几个bat文件(关于robot freamwork安装)

    如果安装后 没有这几文件,或者在运行后 提示 文件缺少这个文件 , 就需要手动创建.   一般文件在 :C:\Python27\Scripts 这个目录下 1.pybot.bat文件: @echo o ...

  4. 聊天机器人開發好消息!!DIALOGFLOW與微信的天作之合!!

    虽然DIALOGFLOW暂未能够与微信(WECHAT)或企业微信(ENTERPRISE WECHAT)进行任何技制上的连接INTERGRATION),确实限制了我们这些聊天机器人开发者的创作空间,因为 ...

  5. react高阶组件的使用

    为了提高代码的复用在react中我们可以使用高阶组件 1.添加高阶组件 高阶组件主要代码模板HOC.js export default (WrappedComponent) => { retur ...

  6. Go语言 切片长度和容量

    package main import "fmt" func main() { s := []int{2, 3, 5, 7, 11, 13} printSlice(s) // Sl ...

  7. JMeter+Ant-自动发送测试结果报告邮件

    build.xml文件 将这三个jar包(activation.jar.commons-email-1.2.jar.mail.jar)放到ant下的lib下 (我的是:/usr/local/Cella ...

  8. JMeter-正则表达式(Json中取value的部分值)

    2019-04-26问题:返回的json中提取短信验证码614930 { : "total":2, : "totalPage":1, : "rows& ...

  9. python数组

    1. 初始化一个具有20个元素,元素的值为 1*1, 2*2, 3*3, ......., n*n的数组 A = [i*i for i in range(1, 20)] print A 2. 初始化一 ...

  10. 关于Oracle的44951事件

    最近有同事遇到某客户数据库产生大量阻塞,等待事件为:enq HW - contention,最开始采用不断杀会话的方式,效果不好,问题一直高频反复.进一步确认SQL是大量的insert,且插入的表中含 ...