day2笔记位运算、变量、输入输出函数

截断法则
在逻辑与运算中,前面为假后面不进行运算
在或中,前面为真后面就不计算

 #include <stdio.h>
int main()
{
int a=5,b=6,c=7,d=8,m=2,n=2;
(m=a<b)||(n=c>d);
printf("%d  %d",m,n);//m=1  n= 2
}

2.#include <stdio.h>
int main()
{
int a=5,b=6,c=7,d=8,m=2,n=2;
(m=a>b)&&(n=c>d);
printf("%d  %d",m,n);//m=0  n=2
}

位运算
位运算:
对二进制补码进行运算

位运算都是对二进制的补码进行操作的
& | ~ ^ << >>
&(位与):全1则1,有0则0;
|(位或):有1则1.全0则0;
~(按位取反):1->0 0->1
^(异或):相同为0, 不同1
对于整数来说有原码 反码 补码
int----4个字节 1个字节=8位 -----》32位
在这里插入图片描述
1:0000 0000 0000 0000 0000 0000 0000 0001
-1:1000 0000 0000 0000 0000 0000 0000 0001
反码: 1111 1111 1111 1111 1111 1111 1111 1110
补码:1111 1111 1111 1111 1111 1111 1111 1111
最高位是符号位
&按位与
int a=5
int b=-2
int c=a&b
printf(“%d”,c)//4
a= 5 原码 反码 补码:
0000 0000 0000 0000 0000 0000 0000 0101
b=-2原码 反码 补码:
原码:1000 0000 0000 0000 0000 0000 0000 0010
反码:1111 1111 1111 1111 1111 1111 1111 1101
补码:1111 1111 1111 1111 1111 1111 1111 1110
&:
0000 0000 0000 0000 0000 0000 0000 0101
结果补码: 0000 0000 0000 0000 0000 0000 0000 0100
结果:4
练习: 6&-3
答案: 4
6: 0 00 0110
-3: 1 00 0011
反码:1 …11… 1100
补码:1 …11… 1101
&:
0 00 0110
答案: 0 …0 … 0100----》4

按位或|
5|-2:
5的原码 反码 补码: 0000 0000 0000 0000 0000 0000 0000 0101
-2补码: 1111 1111 1111 1111 1111 1111 1111 1110
结果的补码:1111 1111 1111 1111 1111 1111 1111 1111
反码:1111 1111 1111 1111 1111 1111 1111 1110
原码:1000 0000 0000 0000 0000 0000 0000 0001 -----》-1
按位异或^
5^-2
5的原码 反码 补码: 0000 0000 0000 0000 0000 0000 0000 0101
-2补码: 1111 1111 1111 1111 1111 1111 1111 1110
^: 补码:1111 1111 1111 1111 1111 1111 1111 1011
反码:1111 1111 1111 1111 1111 1111 1111 1010
原码: 1000 0000 0000 0000 0000 0000 0000 0101-----》-5
异或:相当于减,二进制借1当2
按位取反~
~5:
5的原码 反码 补码: 0000 0000 0000 0000 0000 0000 0000 0101
~:1111 1111 1111 1111 1111 1111 1111 1010
反码:1111 1111 1111 1111 1111 1111 1111 1001
原码:1000 0000 0000 0000 0000 0000 0000 0110—》-6
练习:1. ~15 答案:-16
2.变量x和y的值相等,且为非零值,则以下选项中,结果为0的表达式是(D)
A.x||y B.x|y C.x&y D.x^y
答案:D
3. -4&9 答案:8
左移<<
操作的补码 直接相乘 右边补零
5的原码 反码 补码: 0000 0000 0000 0000 0000 0000 0000 0101
5<<3
0 0000 0000 0000 0000 0000 0000 0101 000 —>32+8=40
-5:1000 0000 0000 0000 0000 0000 0000 0101
反码:1111 1111 1111 1111 1111 1111 1111 1010
补码:1111 1111 1111 1111 1111 1111 1111 1011
-5<<3
1 1111 1111 1111 1111 1111 1111 1011 000
反码:1 1111 1111 1111 1111 1111 1111 1010 111
原码:1 0000 0000 0000 0000 0000 0000 0101 000 —》-40
5<<3
右移>>
右边丢弃 左边补0
5>>2
5的原码 反码 补码: 0000 0000 0000 0000 0000 0000 0000 0101
00 0000 0000 0000 0000 0000 0000 0000 01---->1
5/2^2---->1(向下取整)
-5/2^2----> -2(向上取整)
负数移动
右边丢弃 左边补1
-5>>2:
补码:11 1111 1111 1111 1111 1111 1111 1111 10
反码:11 1111 1111 1111 1111 1111 1111 1111 01
原码:10 0000 0000 0000 0000 0000 0000 0000 10 ----》-2
练习:
3.以下程序升输出结果是()。
int main()
{
char x=040;
printf(“%o\n”,x<<1);
return 0;
}
A.100 B.80 C.64 D.32
答案:A
040–》 01 00 0 00 0—>100

置1公式:a|(1<<n)
置0公式:a&(~(1<<n))n: 要置0或者1位数

a:原本数(要改变的数)

1:0。。。。0001
1|(1<<1)
0。。。。00010
0。。。。00001
结果:0.。。。。00011—》3
运算符
关系运算符

< > >= <= == !=
提醒:1<x<=10 -----> x>1&& x<=10
a != b------>a=1,b=2 ---->1真
a != b------>a=1,b=1 ---->0假
赋值运算符
= += -= = /=
a=10;
a+=10;-----》a=a+10
a
=10;----->a=a10;
条件运算符:(三目运算)
?:
格式:表达式1?表达式2:表达式3
int a=3, b=5;
int c= a>b ? a++ : ++b;
c?----->6
运算规则:先判断表达式1是否成立 如果成立走表达式2,不成立走表达式3
运算符的优先级
单目运算:! ~ ++ –
算术运算:
/ % + -
移位运算:<< >>
关系运算:> < >= <= == !=
位与运算:&
异或运算:^ |
逻辑运算:&& ||
条件运算:?:
赋值运算:= += -= =…
口诀:单算移关与 异或逻条赋
单目运算,从右向左运算
标点符号:, ; () {} []
分割符:换行 空格 tab
变量
概念:在程序运行当中会发生变化的量
定义格式:存储类型 数据类型 变量名
全局变量和局部变量的区别?
在这里插入图片描述
数据类型
char 字符型 1个字节
int 整型 4个字节
short 短整型 2个字节
long 长整型 4个字节
float 单精度浮点型 4个字节
double 双精度浮点型 8个字节
常量
概念:在程序当中不会发生变化的量
分类:
1.字符型常量
用单引号引起来的数据’'就是字符型的数据
只能包裹单个字符
‘a’---->字符a
a-------->变量
’ '------>空格字符
‘\n’------>换行符
‘A’ ‘\x41’ ‘\101’------>字符A
2.字符串常量
多个字符拼接在一起 使用双引号引来的
“hello”----->6个字节 \0:字符串结束的标志
对于一个字符串来说字符串的个数是实际个数+1
sizeof():查看数据所占内存大小 返回值是所占内存的字节数
在这里插入图片描述
3.整型常量
1 2 3 4
一般使用int定义存储
4.浮点型常量
0.9 1.23
小数都是浮点型常量
一般定义使用:float double
5.指数常量
**3
10^3------>3e3
510^3------>5e3
注意:e前面可以是整数也可以是小数 ,但是e的后面只能是整数不可以是小数**
6.标识常量
宏定义:起标识作用 (宏替换 宏代替)
定义格式:#define 宏名 常量或者表达式
宏名遵循标识符的命名规则
在这里插入图片描述
特点:只能单纯的替换 不可以进行运算 ()
例:
#define N 2
#define M N+3 // 2+3
#define NUM N+M/2+1 //2+2+3/2+1 ---->2+2+1+1=6
void main()
{
int a = NUM;
printf(“%d\n”,a);
}
答案:6
#define N 2
#define M 3
N //32
#define T M+N //3
2+2
#define NUM NT+M/2+1 // 232+2+32/2+1 -->12+2+3+1=18
void main()
{
int a = NUM;
printf(“%d\n”,a);
}
答案:18

练习:结合宏定义 三目运算 实现输出宏时 是两个数中最大值
答案:1.int a=1,b=20;
#define MAX a>b?a:b
2.#define MAX(a,b) a>b?a:b
printf(“%d\n”,MAX(10,12));

【2】输入输出

1.按照字符输入输出
输入的是字符 输出也是字符, getchar putchar都是函数实现输入输出
函数三要素:功能 参数 返回值
getchar
int getchar(void);
功能:从终端获取(输入)一个字符
参数:无
返回值:一个int类型的数据 输入字符的ascii码值

在这里插入图片描述
putchar
int putchar(int c);
功能:向终端输出一个字符
参数:c:要输出字符的ascii码值 或者字符
返回值:要输出字符的ascii码值
在这里插入图片描述
练习:1. 用getchar、putchar实现大写字母转换成小写字母
大写-----》小写 ascii+32

在这里插入图片描述
2.按照格式输入输出
printf
int printf(const char *format, …);
功能:按照格式向终端输出
参数:format:字符串 按照字符串中的格式输出
返回值:输出字符的个数
格式:
“%d” int类型 “%f” float类型 “%lf” double类型"%c" char类型"%s" 字符串类型"%#x" 十六进制的数"%#o" 八进制的数"%p" 地址"%e" 指数"%.n" 保留小数点后几位
“%m” 列宽
scanf
int scanf(const char *format, …);
功能:按照格式从终端输入内容
参数:format:字符串 按照字符串中的格式输入
返回值:正确输入的个数
在这里插入图片描述
回收垃圾字符
1.空格
可以回收一个或者多个字符(空格 回车 tab)
在这里插入图片描述
在这里插入图片描述
2.%*c
只能回收一个字符
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值