3.
整型
一般是
4
个字节,
字符型
是
1
个字节,
双精度
一般是
8
个字节:
long int x; 表示 x 是长整型。
unsigned int x; 表示 x 是无符号整型。
注意,
设char s[10]= "abcd",t[]="12345";,则s和t在内存中分配的字节数分别是____D___。
A.6 和 5
B. 6 和 6
C. 10 和 5
D. 10 和 6 // 相当于 ”123456/0”六个
三、算术表达式和赋值表达式
1、算术表达式:+,-,*,/,%
考试一定要注意:“/” 两边
都是
整型的话,结果就是一个整型。 3/2 的结果就是 1. 即将小数部分舍去。
“/” 如果
有一边是
小数,那么结果就是小数。 3/2.0 的结果就是 0.5
“%”符号请一定要注意是
余数
,考试最容易算成了除号。)
%符号两边要
求是整数
。不是整数就错了。
[注意!!!]
2、赋值表达式:表达式数值是最左边的数值,a=b=5;该表达式为 5,常量不可以赋值
。
1、int x=y=10: 错啦,
定义时
,
不可以
连续赋值。
2、int x,y;
x=y=10; 对滴,
定义完成后
,
可以
连续赋值。
3、
赋值的左边只能是
一个变量
。
4、int x=7.7;对滴,x 就是 7
5、float y=7;对滴,x 就是 7.0
3、复合的赋值表达式:
int a=2;
a*=2+3;运行完成后,a 的值是 12。
一定要注意,首先要在 2+3 的上面打上括号。变成(2+3)再运算。
设有语句 int a=3;,则执行了语句 a+=a-=a*=a; 后,变量 a 的值是________。
(1)分析:结果为0,要从后往前算,先运算a*=a,变形为a=axa=9,这时候a被赋值为9,这时候在计算时,a就为9,a-=a相当于a=9-9=0,即最后结果为0。
(2)这里要与a += a-=a*a区别开来,axa没有赋值,所以再次计算的时候a为3,a-=9 ,a=-6,这里赋值了,a+=a相当于a=-6-6=-12.
4、自加表达式:
自加、自减表达式:假设 a=5,++a(是为 6), a++(为 5);
运行的机理:++a 是先把变量的数值加上 1,然后把得到的数值放到变量 a 中,然后再用
这个++a 表达式的数值为 6,而 a++是先用该表达式的数值为 5,然后再把 a 的数值加上 1 为 6,
再放到变量 a 中。 进行了++a 和 a++后 在下面的程序中再用到 a 的话都是变量 a 中的 6
了。
考试口诀
:
++在前
先加后用
,
++在后
先用后加
。
5、逗号表达式:
优先级别
最低
。表达式的数值逗号最右边的那个表达式的数值。
(
2,3,4)的表达式的数值就是 4。
z=
(
2,3,4)
(整个是赋值表达式) 这个时候 z 的值为 4。(有点难度哦!)
z= 2
,
3
,
4
(整个是逗号表达式)这个时候 z 的值为 2。
a=2*6,a*3,a+5
赋值运算符的优先级高于逗号运算符,所以a的值是2*6=12;表达式的值为最后一个逗号表达式的值=a+5=12+5
补充:
1
、空语句
不可以
随意执行,会导致
逻辑错误
。
2、注释是最近几年考试的重点,
注释
不是
C 语言
,不占
运行时间,
没有
分号。
不可以
嵌套!
3、
强制类型转换
:
一定是
(int)a
不是 int(
a),注意
类型上
一定有括号
的。
注意(int)(a+b) 和(int)a+b 的区别。 前是把 a+b 转型,后是把 a 转型再加 b。
4、
三种
取整丢小数
的情况
:
1、int a =1.6;
2、(int)a;
3、1/2; 3/2;
四、字符
1)字符数据的合法形式::
'1'
是
字符
占
一
个字节,
"1"
是字符串占
两
个字节(
含有一个结束符号
)。
'0' 的 ASCII 数值表示为 48,'a' 的 ASCII 数值是 97,'A'的 ASCII 数值是 65。
一般考试表示单个字符错误的形式:'65' "1"
字符是可以进行算术运算的,记住: '0'-0=48
大写字母和小写字母转换的方法: 'A'+32='a' 相互之间一般是相差 32。
2)转义字符:
转义字符分为一般
转义字符、八进制转义字符、十六进制转义字符
。
一般转义字符:背诵\0、 \n、 \’、 \”、 \\。
八进制转义字符: ‘
\141’ 是合法的, 前导的 0 是不能写的。
十六进制转义字符:’\x6d’ 才是合法的,前导的 0 不能写,并且
x 是小写
。
3、
字符型和整数是近亲:两个具有很大的相似之处
char a = 65 ;
printf(“%c”, a); 得到的输出结果:a
printf(“%d”, a); 得到的输出结果:65
五、位运算
1)位运算的考查:会有一到二题考试题目。
总的处理方法:几乎所有的位运算的题目都要按这个流程来处理(
先把十进制变成二进制
再变成十进制
)。
例 1: char a = 6, b;
b = a<<2; 这种题目的计算是先要把 a 的十进制 6 化成二进制,再做位运算。
例 2: 一定要记住,异或的位运算符号” ^ ”。0 异或 1 得到 1。
0 异或 0 得到 0。
两个女的生不出来
。
考试记忆方法:一男(1)一女(0)才可以生个小孩(1)。
例 3: 在没有舍去数据的时候,<<左移一位表示乘以 2;>>右移一位表示除以 2。
1、int x=017; 一定要弄清楚为什么是这个结果!过程很重要
printf(“%d”, x);
15 //%d整型输出
printf(“%o”, x);
17 //%o以八进制数形式输出整数
printf(“%#o”,x);
017 //
printf(“%x”, x);
11 //%x以十六进制数形式输出整数,
printf(“%#x”,x);
0x11
2、int x=12,y=34; 注意这种题型
char z=‘
a’;
printf(“%d ”,x,y);
一个格式说明,两个输出变量,后面的 y 不输出
printf(“%c”,z); 结果为:
a
3、一定要背诵的
举例说明:
printf(“%2d”,123 ); 第二部分有三位,大于指定的两位,原样输出 123
printf(“%5d”,123 ); 第二部分有三位,小于指定的五位,左边补两个空格 123
printf(“%10f”,1.25 ); 小数要求补足 6 位的,没有六位的补 0,。结果为 1.250000
printf(“%5.3f”,125 ); 小数三位,整个五位,结果为 1.250(小数点算一位)
printf(“%3.1f”,1.25 );小数一位,整个三位,结果为 1.3(要进行四舍五入)
第二节 数据输入
1、scanf(“
a=
%d
,b=
%d
”,&a,&b) 考试
超级重点!
一定要记住是
以第一部分的格式在终端输入数据
。考试核心为:
一模一样
。
在黑色屏幕上面输入的为
a=
12
,b=
34
才可以把 12 和 34 正确给 a 和 b 。有一点不同也不
行。
2、scanf(“%d,%d”,x,y);这种写法绝对错误,
scanf 的第二个部分一定要是地址!
scanf(“%d,%d”,&x,&y);注意写成这样才可以!
3、特别注意指针在 scanf 的考察
例如: int x=2;int *p=&x;
scanf(“%d”,x); 错误 scanf(“%d”,p);正确
scanf(“%d”,&p); 错误 scanf(“%d”,*p)错误
4
、指定输入的长度 (考试重点)
终端输入:1234567
scanf(“%2d%4d%d”,&x,&y,&z);x 为 12,y 为 3456,z 为 7
终端输入:1 234567 由于 1 和 2 中间有空格,所以只有 1 位给 x
scanf(“%2d%4d%d”,&x,&y,&z);x 为 1,y 为 2345,z 为 67
5
、字符和整型是近亲:
int x=97;
printf(“%d”,x); 结果为 97
printf(“%c”,x); 结果为 a
6
、输入时候字符和整数的区别(考试
超级重点
)
scanf(“
%d
”,&x);这个时候输入 1,特别注意表示的是整数 1
scanf(“
%c
”,&x);这个时候输入 1,特别注意表示的是字符‘
1’ASCII 为整数 48。
补充说明:
1)scanf 函数的格式考察:
注意该函数的第二个部分是
&a
这样的地址,不是 a;
scanf(“%d%d%*d%d”,&a,&b,&c); 跳过输入的第三个数据。
2)putchar ,getchar 函数的考查:
char a = getchar() 是没有参数的,从键盘得到你输入的一个字符给变量 a。
putchar(‘
y’)把字符 y 输出到屏幕中。
3)
如何实现两个变量 x ,y 中数值的互换(要求背下来)
不可以把 x=y ,y=x;
要用中间变量 t=x;x=y;y=t。
4)
如何实现保留三位小数,第四位四舍五入的程序,(要求背下来)
y=(int)(x*100+0.5)/100.0 这个保留
两位
,对第三位四舍五入
y=(int)(x*1000+0.5)/1000.0 这个保留
三位
,对第四位四舍五入
y=(int)(x*10000+0.5)/10000.0 这个保留
四位
,对第五位四舍五入
这个有推广的意义,注意 x = (int)x 这样是把小数部分去掉