如果输入12 34a回车,则结果a=12,b=3,程序在遇到非法字符a时,会导致程序输入终止,此时a会读入12,b会读入3
如果输入123a回车,则结果a=123,b=-,程序在遇到非法字符a时,会导致程序输入终止,此时a会读入123,而b未能读入指定数据项数
如果在scanf()函数中忘记在变量前加取地址运算符&,会导致非法内存访问
13.%c格式符使用几种情况:
1) 用%c格式读入字符时,空格字符和转义字符(包括回车)都会被当做有效字符读入 例:键盘输入一个整数加法算式:操作数1+操作数2,输出:操作数1+操作数2=计算结果
2) 先输入一个数据后再输入字符型变量时,输入一个数据后,输入的回车符将被当做有效字符读给字符型变量
例:编程从键盘先后输入int型、char型和float型数据,要求每输入一个数据就显示这个数据的类型和数据值
//在输入一个整型数据后,输入的回车符被当做有效字符读给了字符型变量b了
14.%c格式符存在问题的解决方法
1) 用函数get)将数据输入时存入缓冲区中的回车符读入,以避免被后面的字符型变量作为有效字符读入
get);//将存于缓冲区中的回车符读入,避免在后面作为有效字符读入
//函数get)的返回值是一个回车符,已经避免了错误,不需要再将其赋给字符型变量使用
2) 在%c前面加一个空格,将前面数据输入时存于缓冲区的回车符读入,避免被后面的字符型变量作为有效字符读入
//解释:在%c前加空格为什么能将存于缓冲区中的回车符读入
因为如果函数scanf()的格式控制字符串中存在除格式转换说明符以外的其他字符,必须将这些
字符原样输入,所以在%c前加空格,就必须在输入字符型数据前先原样输入空格,而空格,回车符,制表符在
函数scanf()输入数值型数据时都代表输入结束,由实践可知,空格符、回车符、制表符在输入时等效
所以,缓冲区中的回车将代替需要原样输入的空格,因此,实际上,在%c前增加空格或者Tab键都可以完成,
并且与增加的数量无关,且可以混合增加
3)*经典例题:编程实现键盘任意输入字符,统计字母、数字、空格、其他字符数量 首选字符串的方法:
//解释:你可以把Tab控制结束改成其他任意字符,包括字母、数字、/;都可以,
就是不能直接使用回车控制结束,因为你在实际键盘输入时,需要打回车才能把前面的 字符读入,当你输完回车后,就已经换行了,再回车就达不到你要的效果了,不可能把 他读入,但是他会留在缓冲区下一次使用,所以说,理论上任意字符都可以控制结束, 但是不能直接使用回车再回车的方法,而get)函数一次只能读一个字符,当你回车 读入字符后,回车符就会留在缓冲区下一次使用,你可以试试,你把get)这行语句 注释,然后一次输入两个字符再回车的话,那么这时他也只能读入第一个字符,第二个 字符和回车就会计入第二次、第三次的结果。
总结:这种方式与用字符串的区别在于,字符串可以统计任何字符,但是这种方式不能统计 你用来控制结束的字符,比如说,你用/控制结束,那么就不能统计/的数量了,而且你要把 他去掉,因为在整个程序中/只会出现一次,然后就结束了
**当程序中出现两次或以上的键盘输入时,就有可能出现缓冲区的问题,只有一次输入,回车直接结束没有这种问题
15.考点题型:字符串常量的长度问题:
16.考点题型:赋值运算、关系运算的混合运算问题:
// "=="是算术运算符,"="是赋值运算符,优先级:算术运算符>赋值运算符,先判断a==b?是否正确
正确则为真,把1赋给m,"||"是或运算,前面已经为真,所以||后面的就不会再运算了,结果就为真
// a<=b为假,&&是并,前面已经为假,后面就不会再运算了,结果就为假,把0赋给m,即m=0,n=1不变
四、 选择控制结构
1.沃思提出“数据结构+算法=程序”只在面向过程的语言(如C语言)成立
2.算法的正确性衡量方法:
1)有穷性 2)确定性 3)有效性 4)允许没有输入或者有多个输入 5)必须有一个或者多个输出
3.算法的描述方法:
1)自然语言描述 2)流程图描述 3)NS结构化流程图描述 4)伪码描述
4.关系表达式:用作判断条件,结果只有真和假,(n%2!=0)等价于(n%2),0表示假,非0表示真
5.分支结构:当条件P成立时,执行A操作,否则执行B操作;如果B操作为空,即为单分支结构;
如果B操作不为空,即为双分支结构;如果B操作中又包含另一选择结构,则构成多分支选择结构;
6.单分支例题:计算输出两整数最大值
单分支(一般形式):if(表达式P) 语句A
7.双分支例题:计算输出两整数最大值
双分支(一般形式):if(表达式P) 语句1
8.条件运算符是C语言中唯一的三元运算符,需要三个操作数
9.条件运算符例题:计算输出两整数最大值
条件运算符(一般形式):表达式1?表达式2:表达式3
含义:若表达式1为非0,则结果为表达式2的值,否则是表达式3的值
10.多分支控制条件语句(一般形式):
11.条件语句在语法上只允许每个条件分支中带一条语句,而要在分支里处理多条语句 就要使用花括号,构成复合语句
12.随机数的使用方法:
13.例题:猜数游戏:计算机想一个数,人猜对了提示Right!,否则提示Wrong!,并告诉大小 #include
14.switch语句:用于多路选择,一般情况大于三种,用开关语句代替条件语句
可执行语句序列1 //注意:语句序列不使用花括号
可执行语句序列n+1
3)switch后圆括号内的表达式只能是char型或int型
4)关键字case后接常量,类型与表达式类型一致,常量的值必须互不相同
5)常量与case中间至少有一个空格,常量后面是冒号
6)case本身并没有条件判断的功能,若case后面的语句省略不写,则表示它与后续case执行相同的语句
7)switch语句的执行过程:
第一步,计算switch后表达式的值
第二步,将表达式的值依次与case后的常量比较
第三步,如果相等,执行case后的代码段,执行完毕,可使用break语句跳出switch语句
如果没有break语句,不会再比较,程序将依次执行下面的case后的语句,直到遇到break或者switch的}为止
15.例题:编程实现简单计算器功能
{ //因为赋值表达式左值必须是变量,如果把==误写成=,会提示错误
//break;这句一般不需要,因为没有break就会依次执行下面的步骤直到break或者switch的}
16.例题:编程实现简单计算器功能,能进行浮点数运算,操作数与运算符之间可加入任意多个空格
//内存中的浮点数所表示的精度是有限的,所以比较实型变量data2与0是否相等时, 不能像整型变量与0比较那样直接用相等关系运算符与0比较,而应使用如下方式判断 实型变量data2的值是否位于0附近的一个很小的区间内,即:if(fabs(data2)<=1e-7)
17.逻辑运算符和逻辑表达式
逻辑非:!,单目运算符,右结合, 优先级最高
逻辑与:&&,双目运算符,左结合,优先级较高
逻辑或:||,双目运算符,左结合,优先级较低
例:判断某一年year是否是闰年的条件:
1) 能被4整除,但不能被100整除;
1)能被400整除
18.特别注意:在计算含有逻辑运算符(&&和||)的表达式时,通常尽量使用最少的操作数来 确定表达式的值,这就意味着表达式中的某些操作数可能不会被计算。
1)程序测试只能证明程序有错,不能证明程序无错
2)例:编程输入三角形三边长a,b,c,判断他们能否构成三角形,能构成什么三角形 #include
3)例:编程将输入的百分制成绩转换为五分制成绩输出
20.对输入非法字符的检查与处理
1)例:输入两个整型数,计算并输出两个整数的最大值
1.如果输入3.2,1则输出3
2.如果输入1,3.2则输出3
3.如果输入q则输出-
if(ret!=2)//返回在遇到非法字符前已成功读入的数据项数
//但是scanf()函数不做类型检查,所以输入1,3.2会输出3
21.位运算符的使用
1)位运算是对字节或字内的二进制数位进行测试、抽取、设置或移位等操作
2) 位运算的操作对象只能是char和int类型
3) C语言中共有6种位运算符,只有按位取反是单目运算符,其他都是双目运算符
4)关系运算和逻辑运算的结果要么是0,要么是1,而位运算结果可为任意值,但每一位都只能是0或1
5)6种位运算符:
按位取反 ~ 用于加密处理,一次求反加密,二次求反解密
按位与 & 用于对字节中某位清零
按位或 | 用于对字节中某位置1
例:将15的最低位不变,其余位清零 15&1=1
例:将15的最高位不变,其余位均置1 15|127=127
例:将15左移1、2、3位的二进制补码如下
初始字节内容 对应十进制15
左移1位字节内容 对应十进制30
左移2位字节内容 对应十进制60
左移3位字节内容 对应十进制120
x>>n 表示把x的每一位向右移n位,当x为有符号数时,左边空位补符号位值―算术移位
当x为无符号位时,左边空位补0―逻辑移位
例1:将15右移1、2、3位的二进制补码如下
初始字节内容 对应十进制15
右移1位字节内容 对应十进制7
右左移2位字节内容 对应十进制3
右移3位字节内容 对应十进制1
例2:将-15右移1、2、3位的二进制补码如下
初始字节内容 对应十进制-15
右移1位字节内容 对应十进制-8
右左移2位字节内容 对应十进制-4
右移3位字节内容 对应十进制-2
12) 无论左移位还是右移位,从一端移走的位不移入另一端,移走的位的信息就丢失了
13)左移位和右移位可以分表代替整数的乘法和除法,左移n位相当于乘以2^n,右移n为相当于除以2^n
14) 例:写出运行结果
1.循环:包括计数控制的循环和条件控制的循环
2.结构化程序设计的三种基本结构:顺序结构、选择结构、循环结构
3.循环结构的类型:
1)当型循环结构:for语句(适合循环次数已知,计数控制的循环)
2)直到型循环结构:while语句、do-while语句(适合循环次数未知,条件控制的循环)
while(循环控制表达式)
语句系列 |循环体
2)循环控制表达式在执行循环体之前测试
计算循环控制表达式的值
如果循环控制表达式的值为真,那么执行循环体中的语句,并返回步骤1
如果循环控制表达式的值为假,就退出循环,执行循环体后面的语句
语句系列 |循环体
2)循环控制表达式在执行循环体之后测试
执行循环体中的语句
计算循环控制表达式的值
如果循环控制表达式的值为真,那么返回步骤1
如果循环控制表达式的值为假,就退出循环,执行循环体后面的语句
for(初始化表达式;循环控制表达式;增值表达式)
语句系列 |循环体
2) 在每次循环体被执行之前,都要对循环控制条件测试一次,每次循环体执行完以后都要执行一次增值表达式
3)初始化表达式作用:循环变量初始化,即赋初值
4)循环控制表达式:是控制继续执行的条件,当表达式的值为非0时重复执行循环
5)增值表达式作用:每执行一次循环,循环控制变量增值
6)for语句三个表达式之间用分号分隔,有且只能有两个分号
7)循环控制表达式若省略,表示循环条件为永真
8)初始化表达式和增值表达式都可省略,但是必须有其他语句反应其作用
7.例:从键盘输入n,然后计算输出1+2+3+??n的值
1)while语句编程实现
3)for语句编程实现
1)所有运算符中优先级最低,左结合
2)作用:可实现对各个表达式的顺序求值
3)结果:将最后一个表达式的值作为整个逗号表达式的值
4)例:从键盘输入n,然后计算输出1+2+3+??n的值