A选项:C语言中,一共有3种结构。分别是顺序结构、选择结构(else-if语句)、循环结构(for、while语句)。因此,C语言具有结构化特征。
B选项:不仅能解决简单问题,3种基本结构能够解决所有问题。复杂问题需要三种基本结构的结合使用;链表、二叉树等是程序的实现思想,而非程序的实现结构。
C选项:使用goto语句,程序员可以从程序的一个部分无条件跳转到另一个部分,这种跳转使得程序的流程不再是自顶向下的顺序流,而是变成了难以预测的跳跃流,大大破坏了程序的结构性。 在复杂的程序中,过多的goto语句会使得程序的执行流程变得极为复杂,导致程序难以理解和维护。 结构化编程提倡的是通过循环、条件判断等结构化的流程控制来管理程序的流程,这有助于保持程序的清晰和条理,也便于其他开发人员阅读和理解。
D选项:程序自顶向下运行,因此采用自顶向下的程序设计方法是最优的。
逐步细化的例子:循环语句里内嵌多条选择语句,不断地加强程序健壮性。
标识符:在编程语言中,标识符是用户编程时使用的名字,变量、常量、函数、语句块都有名字。是用来标识某个实体的一个符号,是对变量名、函数名、标号和其他各种用户定义的对象命名。
C语言中标识符的命名规范:
- 1.标识符由字母、数字、下划线组成,并且首字母不能是数字。
- 2.不能把C的关键字作为用户的标识符,例如:if、for、while等。(注:标识符不能和C语言的关键字相同,也不能和用户自定义的函数或C语言库函数同名)
- 3.标识符长度是由机器上的编译系统决定的,一般的限制为8字符,(注:8字符长度限制是C89标准,C99标准已经扩充长度,其实大部分工业标准都更长)。
- 4.标识符对大小写敏感,即严格区分大小写。
(x+1)已经可以看作是常数3,++或--的算子只能是变量,若是常数即报错。
注:其他3个选项都是做了一定的计算后,进行了赋值操作。*= 会自动给赋值号右边的表达式加上一个括号。
通过高中知识,我们不难得出:(x-y)的区间在 (-10,10)。因此B选项正确,C选项错误。
C选项代表的是|x-y|>10的情况。
代码段功能:s为a即i=1,s为b即i=2,s为a、b以外的字符i保持未定义状态。
A、C、D选项:假设s为c,那么i=2,与代码段功能不同。
未进循环语句,因此循环0次。
这个C语言程序中定义了一个函数
fun
,它有一个静态局部变量a
,初始值为3。静态局部变量在函数第一次被调用时初始化,并在后续的函数调用中保持其值。程序的
main
函数中,首先调用fun(k)
,此时k
的值为1,因此a
的值变为3 + 1 = 4
,并且fun
函数返回4。接着,程序再次调用
fun(m)
,此时m
的值为2,但由于a
是静态变量,它的值仍然是上一次调用fun
时的值,即4。因此,a
的值变为4 + 2 = 6
,并且fun
函数返回6。最后,程序输出变量
n
的值,此时n
的值为6。因此,程序的输出结果是6,选项C是正确的。
C语言中,只有在初始化时可以对字符串数组进行代码端的赋值;赋值时可以是字符组成的数组形式,也可以是字符串字面量形式。并且初始化时可以不声明数组的大小,编译器会自行判断。因此A、B错误,D对。
C中要将str2的数据全部存入str1,需要用到strcpy函数;初始化以后要从程序端输入program这串字符需要使用getchar、gets或者scanf函数。
突发奇想的问题:
问题1:getchar、gets和scanf函数的区别是?
答:
getchar
用于读取单个字符,包括空白字符。函数无参数,可以通过 str[i] = getchar() 的方式来输入(结合循环语句,循环退出条件为遇见 '\0')。gets
用于读取一行字符串,直到遇到换行符停止。函数参数为某个字符串数组。scanf
可以读取不同类型的数据,包括整数、浮点数、字符和字符串。它使用格式字符串来指定输入的格式。对于字符串,scanf
会读取直到遇到空白字符(空格、制表符或换行符)为止。函数参数为某个字符串数组。问题2:为什么对于scanf函数来说,输入字符串时,字符串数组不需要加上取地址符号?
答:对于整型数组,其元素都是整型,即使数组本身可以看作是一个指向整型的指针(例如arr[0]可以看作指针指向数组第一个元素),但因为想要通过函数来改变实参(scanf是库函数中的一员),那么就需要传整型数据的地址(&arr[0])。
而对于字符串数组来说,其元素都是指向字符的指针(例如 'a',实际上是指向a的指针),所以不需要再加上取地址操作了。
在这段代码中,我们首先定义了一个整型数组
a
,它包含10个元素,并且使用初始化列表来初始化这些元素。然后,我们定义了两个指针p1
和p2
,其中p1
被初始化为指向数组a
的第一个元素,而p2
被初始化为指向数组a
的第六个元素(索引为5)。代码中的
printf
语句输出的是指针p2
和p1
之间的差值。在C语言中,两个同类型指针相减得到的是它们之间的元素数量,而不是字节数。因此,p2 - p1
计算的是p2
和p1
之间有多少个数组元素。由于
p1
指向数组的第一个元素(索引为0),而p2
指向数组的第六个元素(索引为5),它们之间的元素数量是5 - 0 = 5
。因此,正确的输出值是
5
,选项 D 是正确的。
s的next搞成NULL,p往下走一个结点,p的下一个结点搞成data为30的那个。
传参时,数组名表示的是数组首元素。
由于
gets
函数会读取直到遇到换行符,因此应该使用strlen(s)
来获取字符串s
的长度,然后遍历到字符串的末尾。所以填空(1)的答案是strlen(s)
。在C语言中,使用
%s
来表示字符串的格式占位符,所以填空(4)的答案是"%s"
。
第一处:因为宏定义是直接替换文本,而非赋值。因此无需等号。
1.e-8 是科学计数法中10^(-8) 的表示方法,C语言同样支持科学计数法的表达方式。
第二处:前面定义了distance是float型数据,因此在使用scanf输入distance数据时,类型声明应该保持float型。
第三处:此处还需要进行不同情形的细化(即仍然需要有判断语句的出现),因此使用else if。
第一处:函数提前声明时,需要给到参数的类型。
第二处:题设中提到了最后一项的绝对值要小于1.e-5;然而原代码中,循环的进入条件是最后一项小于等于1.e-5,颠倒过来即可。
第三处(送分处,当然是我把分数送给出题老师啦 w v w):本处错误需要对照题设中的泰勒级数数字规律来进行修改。
分子上,泰勒级数的数字规律为前后两项分别都有2个x,同时前后两项需要相乘,即 x*x*x*x;此外,我们可以发现 t 上分子已经有2k个x相乘(k>=1,k∈Z),所以就可以把 t 依然视作一个分数,与数学规律分式相乘;而数学规律分式的分子处使用 x*x。
分母上,泰勒级数的数字规律是公差为1的等差级数(例如2!、3!、4!、……)。
第一、第二处:结构体声明需要加上名字;不加上0就处于未初始化的状态,有不满足需求的风险。
第三处:数组下标从0开始算,到4结束而非5。
第四处:结构体数组使用有问题。
#include <stdio.h>int main(void)
{int num1,num2,num;printf("请输入一个长度为2的正整数:");scanf("%d",&num);num1=num/10;num2=num%10;if(num1==1){switch(num2){case 1:printf("A楼干垃圾"); break;case 2:printf("A楼湿垃圾"); break;case 3:printf("A楼可回收垃圾"); break;case 4:printf("A楼有害垃圾"); break;default:printf("输入的整数不是有效标签!");} }else if(num1==2){switch(num2){case 1:printf("B楼干垃圾"); break;case 2:printf("B楼湿垃圾"); break;case 3:printf("B楼可回收垃圾"); break;case 4:printf("B楼有害垃圾"); break;default:printf("输入的整数不是有效标签!");}}else{printf("输入的整数不是有效标签!");}return 0;
}
#include <stdio.h>int main(void)
{char ch[100];printf("请输入0和1组成的字符串:\n");scanf("%s",ch);int i,count=0;for(i=0;ch[i];i++){if(ch[i]=='1'){count++;}}if(count%2==1){ch[i]='1';ch[i+1]='\0';}if(count%2==0){ch[i]='0';ch[i+1]='\0';}printf("%s",ch);return 0;
}