C语言应试笔记。
int main() { int a, b, c, d, m, n; a = b = c = d = m = n = 0; if ((m = a == b) || (n = c == d)) { a = b = c = d = 3; }
printf("%d,%d“,m,n); return 0; }
先看以上代码,本题 的考点为 if ((m = a == b) || (n = c == d)) 。在||逻辑运算中如果前面的(m=a==b)=1了,其后面的(n=c==d)不会再进行运算。这也是著名的C语言中的(短路原则)!
2、对于+=、-=、*=、/=、%=
首先看几个例子
score+=20; 等价于 socre=score+20;
dimes-=2; 等价于 dimes=dimes-2;
bunnies*=2; 等价于bunnies=bunnies*2;
time/=2.73; 等价于time=time/2;
reduce%=3;等价于reduce=reduce%3;
来看一道题目
int main() { int a = 5; a -= a * a; printf("%d", a);//a - (a * a); return 0; }
这个地方的a-=a*a;我们可以直接堪称a=a-(a*a)后面的a*a看成一个整体括起来再做答案为-20;
3
int main() { float y = 0; float x = 1.0; y = x + 5 / 2; printf("%.3f", y); return 0; }
5/2按照C语言中的规则5/2=2,由于x为1.0所以y为3.0,但是printf需要输出三位小数所以答案为3.000;
4 应试最常考的题目:辗转相除法(求最大公约数)
//核心算法不失一般性令a>b; if(a<b){ tmp=a,a=b,b=tmp; }
p=a*b;//求最小公倍数备用 while(b){//直到b为0时停止循环 tmp=a%b,a=b,b=tmp; }
max=a;//最大公约数
Min=p/a;//最小公倍数
请看例子:a=20 b=8;
第一个循环:tmp=4;a=8;b=4;
第二个循环:tmp=0;a=4;b=0;
停止。
输出最大公约数为:a=4。
求最小公倍数可以在求最大公约数上进行运算
5、普及一个概念什么是完全数。
from Baidu百科
如果一个数恰好等于它的因子之和,则称该数为“完全数”。第一个完全数是6(1,2,3),第二个完全数是28(1,2,4,7,14),第三个完全数是496,后面的完全数还有8128、33550336等等。
6