[c/c++] programming之路(31)、位运算(二)
一、取反的高级用法
#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)、位运算(二)的更多相关文章
- 剑指offer 11. 位运算 二进制中1的个数
题目描述 输入一个整数,输出该数二进制表示中1的个数.其中负数用补码表示. //思想:用1(1自身左移运算,其实后来就不是1了)和n的每位进行位与,来判断1的个数 private stat ...
- Mysql 查询—按位运算
前言:虽说这是件小事儿,但本宝宝思前想后,还是为它留下一笔,嘿嘿.反正写博客不浪费纸和笔!好久没有开启我的逗比模式了,我亲爱的乖徒弟DBA,DBB,DBAA等,好久不见你们,遥祝幸福快乐+DB. 整个 ...
- zoj--3870--Team Formation(位运算好题)
Team Formation Time Limit: 3000MS Memory Limit: 131072KB 64bit IO Format: %lld & %llu Submit ...
- [c/c++] programming之路(30)、位运算(一)
一.取反 ~ #include<stdio.h> #include<stdlib.h> void main(){ unsigned ; //0000 1111 char的单位是 ...
- 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 ...
- Java 位运算2-LeetCode 201 Bitwise AND of Numbers Range
在Java位运算总结-leetcode题目博文中总结了Java提供的按位运算操作符,今天又碰到LeetCode中一道按位操作的题目 Given a range [m, n] where 0 <= ...
- SQL Server时间粒度系列----第8节位运算以及设置日历数据表节假日标志详解
本文目录列表: 1.位运算 2.设置日历数据表节假日标志 3.总结语 4.参考清单列表 位运算 SQL Server支持的按位运算符有三个,分别为:按位与(&).按位或(|).按位异或 ...
- JavaScript 位运算总结&拾遗
最近补充了一些位运算的知识,深感位运算的博大精深,此文作为这个系列的总结篇,在此回顾下所学的位运算知识和应用,同时也补充下前文中没有提到的一些位运算知识. 把一个数变为大于等于该数的最小的2的幂 一个 ...
- javascript 位运算
位运算博大精深,本文总结下基本的位运算的概念. 1.整数的二进制码 位操作符用于在最基本的层次上,即按内存中表示数值的位来操作数值.ECMAScript中的所有数值都以IEEE-754 64位格式存储 ...
- javascript位运算
javascript作为一门高级语言,他尽量让开发人员减少思考底层的硬件工作原理,而将精力集中在逻辑开发的层面.不过,不论这门语言多么高级,我们必须知道数据依然以bits的形式存储,有时候我们会直接与 ...
随机推荐
- Python全栈-magedu-2018-笔记9
第三章 - Python 内置数据结构 封装和解构 封装 将多个值使用逗号分割,组合在一起 本质上,返回一个元组,只是省掉了小括号 python特有语法,被很多语言学习和借鉴 t1 = (1,2 ...
- Spring中加载xml配置文件的常用的几种方式
https://blog.csdn.net/qq877507054/article/details/62432062
- javascript 表达式
// for(表达式1;表达式2;表达式3){// 循环体语句;// }// 先执行表达式1,在执行2表达式,// 如果2表达式结果为false,退出循环 ...
- Python+Selenium+PageObject
一.安装page_objects测试库 二.目录介绍 1.pages包:用于各界面元素定位,如BaseLoginPage.py 2.testcases包:用于编写各功能测试用例,如Login.py 3 ...
- Create-React-App创建antd-mobile开发环境
Facebook 官方推出Create-React-App脚手架,基本可以零配置搭建基于webpack的React开发环境,内置了热更新等功能. 详细文档可前往链接:Create-React-App文 ...
- 洛谷P4778 Counting swaps 数论
正解:数论 解题报告: 传送门! 首先考虑最终的状态是固定的,所以可以知道初始状态的每个数要去哪个地方,就可以考虑给每个数$a$连一条边,指向一个数$b$,表示$a$最后要移至$b$所在的位置 显然每 ...
- spring框架学习之--数据库操作增删改查
基于spring的NamedParameterJdbcTemplate操作数据库 首先在 resources 文件夹下添加数据库配置文件jdbc.properties 配置常用的数据库信息 consu ...
- 游戏全区全服和分区分服 QQ斗地主的设计
游戏全区全服和分区分服 QQ斗地主的设计 https://cloud.tencent.com/community/article/164816001481011910?fromSource=gwzc ...
- js中把ajax获取的数据转化成树状结构(并做成多级联动效果)
1.首先通过ajax获取数据,此处省略,直接贴出获取到的数据格式 var arr = [{ id: 1, name: "一级标题", pid: 0 }, { id: 2, name ...
- Oracle安装和配置Oracle数据库快速指南
Oracle安装12C要求参考文档 汇总 中文版:在 Unix AIX,HP-UX,Linux,Solaris 和 MS Windows 操作系统上安装和配置 Oracle 数据库(RDBMS)的要求 ...