- 下面代码的结果是:( )
#include <stdio.h>
int main()
{
int a, b, c;
a = 5;
c = ++a;
b = ++c, c++, ++a, a++;
b += a++ + c;
printf("a = %d b = %d c = %d\n:", a, b, c);
return 0;
}
- A.a = 8 b = 23 c = 8
- B.a = 9 b= 23 c = 8
- C.a = 9 b = 25 c = 8
- D.a = 9 b = 24 c = 8
解析:
++运算符:分为前置++和后置++,
前置++:先加1,后使用,即先使用变量中内容,然后给结果加1
后置++:先使用变量中内容,整个表达式结束时,给变量加1
逗号表达式,取最后一个表达式的值。
#include <stdio.h>
int main()
{
int a, b, c;
a = 5;
c = ++a;// ++a:加给a+1,结果为6,用加完之后的结果给c赋值,因此:a = 6 c = 6
b = ++c, c++, ++a, a++;
// 逗号表达式的优先级,最低,这里先算b=++c, b得到的是++c后的结果,b是7
// b=++c 和后边的构成逗号表达式,依次从左向右计算的。
// 表达式结束时,c++和,++a,a++会给a+2,给c加1,此时c:8,a:8,b:7
b += a++ + c; // a先和c加,结果为16,在加上b的值7,比的结果为23,最后给a加1,a的值为9
printf("a = %d b = %d c = %d\n:", a, b, c); // a:9, b:23, c:8
return 0;
}
因此:选择B
- 下面代码输出的结果是啥:
#include <stdio.h>
int main()
{
int a = 7;
int b = 2;
float c = 2.0f;
printf("%d\n", 3);
printf("%f\n", a / c);
return 0;
}
- A.3 3.500000
- B.3.500000 3.500000
- C.3.500000 3
- D.3 3
解析:
两个整数相除,执行的是整数除法,计算的结果也是整数
除法的两个操作数只要有一个数是浮点数,执行的就是小数除法,所以a/c是按照小数除法计算的,结果就是3.5
- 关于C语言算术操作符说法正确的是?
- A.除号两边都是小数才能执行小数除法
- B.%操作符的操作数可以是整数,也可以是小数
- C.%操作符计算的结果是两个操作数整除之后的商
- D.负数求模的规则是,结果的正负号由第一个运算数的正负号决定。
解析:
A:除号两边只要有一个是小数,就执行小数除法
B:%操作符的操作数只能是整数
C:%操作符计算的结果是两个操作数整除之后的余数
- 下面程序输出的结果是啥:
#include <stdio.h>
int main()
{
printf("%5d\n", 123456);
return 0;
}
- A.12345
- B.123456
- C.23456
- D.0
解析:
printf()
允许限定占位符的最小宽度。%5d表示这个占位符的宽度至少为5位。如果不满5位,对应的值的前面会添加空格。如果超过5位,正常输出就行,5是最少输出5位。
- 关于printf函数说法错误的是?
- A.printf()的作用是将参数文本输出到屏幕。它名字里面的f代表format(格式化),表示可以定制输出文本的格式。
- B.printf()不会在行尾自动添加换行符,运行结束后,光标就停留在输出结束的地方,不会自动换行。
- C.printf()可以在输出文本中指定占位符,“占位符”,就是这个位置可以用其他值代入。
- D.printf()参数与占位符是一一对应关系,如果有n个占位符,printf()的参数就应该有n个
解析:
printf()参数与占位符是一一对应关系,如果有n个占位符,printf()的参数就应该有n+1个。
- 关于scanf函数说法正确的是?
- A.scanf中也有占位符,占位符和后边的参数提供的地址一一对应。
- B.scanf()处理所有占位符时,会自动过滤起首的空白字符,包括空格、制表符、换行符
- C.scanf的占位符%s表示读取一个字符串,遇到空白字符也全部读取
- D.scanf是库函数,库函数不需要包含头文件
解析:
B:scanf()处理数值占位符时,会自动过滤空白字符,包括空格、制表符、换行符,scanf输出字符占位符%c的时候,不忽略空白字符,总是返回当前第一个字符,无论该字符是否为空格。
C:scanf的占位符%s表示读取一个字符串,遇到空白字符就停止读取。
D:scanf需要包含stdio.h这个头文件的
- 代码:你是天才吗?
描述
据说智商140以上者称为天才,KiKi想知道他自己是不是天才,请帮他编程判断。输入一个整数表示一个人的智商,如果大于等于140,则表明他是一个天才,输出“Genius”。
输入描述:
多组输入,每行输入包括一个整数表示的智商。
输出描述:
针对每行输入,输出“Genius”。
示例1
输出:160
输出:Genius
#include <stdio.h>
int main() {
int a;
while (scanf("%d", &a) != EOF) {
if(a>=140)
{
printf("Genius");
}
}
return 0;
}
- 代码:判断2个数的大小
描述
KiKi想知道从键盘输入的两个数的大小关系,请编程实现。
输入描述:
题目有多组输入数据,每一行输入两个整数(范围-231~231-1),用空格分隔。
输出描述:
针对每行输入,输出两个整数及其大小关系,数字和关系运算符之间没有空格,详见输入输出样例。
示例1
输入:1 1
输出:1=1
示例2
输入:1 0
输出:1>0
示例3
输入:0 1
输出:0<1
#include<stdio.h>
int main() {
int a,b;
while (scanf("%d%d", &a, &b)!=EOF){
if (a > b) {
printf("%d>%d\n", a, b);
}
else if (a == b) {
printf("%d=%d\n", a, b);
}
else {
printf("%d<%d\n", a, b);
}
}
return 0;
}
- 代码:被5整除问题
描述
判断一个整数是否能5整除是一个挺简单的问题,懒惰的KiKi还是不想自己做,于是找到你帮他写代码,你就帮帮他吧。
输入描述:
输入包括一个整数M(1≤M≤100,000)。
输出描述:
输出包括一行,如果M可以被5整除就输出YES,否则输出NO(结果大小写敏感)。
示例1
输入:10
输出:YES
示例2
输入:9
输出:NO
#include <stdio.h>
int main() {
int M;
scanf("%d",&M);
if (M % 5 == 0) {
printf("YES");
}
else {
printf("NO");
}
return 0;
}
- 代码:线段图案
描述
KiKi学习了循环,BoBo老师给他出了一系列打印图案的练习,该任务是打印用“”组成的线段图案。
输入描述:
多组输入,一个整数(1~100),表示线段长度,即“”的数量。
输出描述:
针对每行输入,输出占一行,用“*”组成的对应长度的线段。
#include <stdio.h>
int main() {
int a,i;
while (scanf("%d", &a) != EOF) {
for (i = 1; i <= a; i++) {
printf("*");
}
printf("\n");
}
return 0;
}