大一上C语言错题集
1
答案解析:定义如此。
答案解析:题目要求需要输入,A B D排除。
答案解析:字符数组需要输入单个字符,而不是字符串。
答案解析:C 语言规定,只能逐个引用数组元素,而不能一次引用整个数组。
答案解析:数组名就是一个常量指针。
答案解析:可以使指针自增(减)来指向不同的数组元素。
答案解析:定义如此。
8
在这里插入代码片冒泡法排序:本题要求将给定的n个整数从小到大排序后输出。输出时相邻数字中间用一个空格分开,行末不得有多余空格。
#include
# define MAXN 10
int main()
{
int i, index, j, n, repeat, temp;
int a[MAXN];
for(repeat = 1; repeat <= 4; repeat++){
scanf("%d", &n);
for(i = 0; i < n; i++){
scanf("%d", &a[i]);
}
for( i = 1; i < n; i++ ){
for
(j = 0; j < n-i; j++ )
{
if
(a[j] > a[j+1])
{
temp = a[j]; a[j] = a[j+1]; a[j+1] = temp;
}
}
}
for(i = 0; i < n; i++) {
if
(i == 0)
{
printf("%d", a[i]);
}else{
printf(" %d", a[i]);
}
}
printf("\n");
}
return 0;
}
答案解析:理解每个变量的用意,熟记即可。
9
在这里插入代码片
选择法排序:本题要求将给定的n个整数从小到大排序后输出。输出时相邻数字中间用一个空格分开,行末不得有多余空格。
#include
# define MAXN 10
int main()
{
int i, index, k, n, temp;
int a[MAXN];
scanf("%d", &n);
for(i = 0; i < n; i++){
scanf("%d", &a[i]);
}
for(k = 0; k < n-1; k++){
index =
k
;
for
(i = k + 1; i < n; i++)
{
if
(a[i] < a[index])
{
index = i;
}
}
temp = a[index]; a[index] = a[k]; a[k] = temp;
}
for(i = 0; i < n; i++) {
if
(i == 0)
{
printf("%d", a[i]);
}else{
printf(" %d", a[i]);
}
}
printf("\n");
return 0;
}
答案解析:理解每个变量的用意,熟记即可。
10
在这里插入代码片大小写字母转换。以下程序段A和B的功能都是:将字符串中的小写字母全部转换成大写字母,大写字母全部转换成小写字母,其他字符不变。
/* 程序段A */
int k;
char str1[81];
k = 0;
while (str1[k] != '\0') {
if (str1[k] >= 'a' && str1[k] <= 'z'){
str1[k] = str1[k]-'a'+'A';
}
else if (str1[k] >= 'A' && str1[k] <= 'Z'){
str1[k] = str1[k]-'A'+'a';
}
k++;
}
/* 程序段B */
int k;
char str1[81], str2[81];
k = 0;
while (str1[k]!='\0') {
if (str1[k]>='a' && str1[k]<='z'){
str2[k] = str1[k]-'a'+'A';
}
else if (str1[k]>='A' && str1[k]<='Z'){
str2[k] = str1[k]-'A'+'a';
}
else{
str2[k] = str1[k];
}
k++;
}
str2[k] = '\0';
答案解析:注意答案后是否有;。
11
在这里插入代码片
字符串复制。
以下程序段的功能是:将字符串str1的内容复制到字符串str2。
int i;
char str1[81], str2[81];
i = 0;
while
(str1[i] != '\0')
{
str2[i] = str1[i];
i++;
}
str2[i] = '\0';
答案解析:注意答案后是否有;。
12
变量被定义后 , 它不仅有一个确定的地址值 , 而且还会有一个确定的本身值。
F
答案解析:需要赋值后才会有一个确定的本身值。
13
若有函数max(a,b),为了让函数指针变量p指向函数max,正确的赋值方式是( )。 (2分)
A p=max;
B *p=max;
C p=max(a,b);
D *p=max(a,b);
A
答案解析:把max函数的入口地址赋给指针p即可。
14
设变量已正确定义,以下()是合法的C语句。
A
if ( n <= 10 );
B
switch ( k ) {
case 1: printf("one"); break;
case 2: printf("two"); break;
case 1: printf("one"); break;
default: printf("zero"); break;
}
C
switch ( k%2 ) {
default: printf("zero"); break;
case 1: printf("one");
case 1+1: printf("two");
}
D
n = 10;
switch ( k ) {
case n%3: printf("one");
case n%4: printf("two");
default: printf("zero");
}
答案 A C
答案解析:B:一个case值只能使用一次,不可重复使用。D:K为跳转变量。
15
关于C语言中的函数,下列说法正确的是
A 函数应该以它们调用的顺序来定义。
B return 语句可以出现在函数的任何地方。
C 函数定义可以在主函数前面也可以在主函数后面。
D 函数总是返回一个整型数据。
答案 BC
答案解析:A:函数定义不需要按使用循序定义。D:函数返回值由函数声明时决定。
16
下面函数用于求出两个整数之和,并通过形参传回两整数相加之和值。请填空。
void add(int x, int y, int *z)(1)
{
*z = x + y; (2)
}
答案解析:注意*的位置。
17
下面程序可以逐行输出由language数组元素所指向的5个字符串。请填写程序中相应语句。
#include
int main(void)
{
char *language[] = {“BASIC”, “FORTRAN”, “PROLOG”, “JAVA”, “C++” } ;
char **q ; (1)
int k ;
for(k = 0 ; k < 5 ; k++) {
q= language+k ; (2)
printf("%s\n", *q);
}
return 0;
}
答案解析:明确q的在函数中的作用。
18
设int a[2][3]={{2},{3}};则数组元素a[1][0]的值为3.
答案:a[1][0]
答案解析:方括号打好。
19
C stores lists of values in array.
答案解析:认真审题,加强理解题目的意思。
20
设有定义语句:int a[ ][3]={{0},{1},{2}}; 则数组元素 a[1][2]的值是 0
答案:随机值
答案解析:没有被赋值的元素都是一个随机值。
21
单向链表中的每个结点都需要动态分配内存空间。
答案 : T
答案解析:链表中每个节点都是需要动态分配内存空间的,需要使用时就给出,不需要时就回收。
22
通常使用结构的嵌套来定义单向链表结点的数据类型。
答案:T
答案解析:方便。
23
在一个以 h 为头的单向链表中,p 指针指向链尾的条件是()。
A p->next=h
B p->next=NULL
C p->next->next=h
D p->.data=-1
答案:A
答案解析:链表为不带头结点的,然后循环链表首尾相连即尾的next指向了头,如果要求p指向尾,则肯定有p->next=h。
24
在一个单链表head中,若要删除指针p所指结点的后继结点,则执行()。
A p=p->next;free§;
B p->next=p->next->next; free§;
C q= p->next q->next=p->next; free(q);
D q=p->next; p->next=q->next; free(q);
答案:D
答案解析:将p节点指向的下一个节点的地址,赋值给p的上一个节点,之后释放q。
25
完成下列打印带头单链表的各元素的算法()。
typedef struct List
{
int data;
struct List next;
} Node,Link;
void printlk(Link head)
{
Link p=head->next;
while( (1) )
{
printf(“%d\n”,p->data);
(2)
}
}
A p
B p=p->next
C p->next=p->next->next;
D free§;
答案: C
答案解析: 使p下个地址的下个地址赋给p的下个地址。
26
调用strcmp函数比较字符串大小时,通常较长的字符串会较大。
F
答案解析:需要比较的是字符串ASCII的大小。
27
假设结构指针p已定义并正确赋值,其指向的结构变量有一个成员是int型的num,则语句 *p.num=100; 是正确的。
F
答案解析:应该用->。
28
若变量已正确定义并且指针p已经指向某个变量x,则(*p)++相当于____。
A p++
B x++
C *(p++)
D &x++
答案:B
答案解析:*p是x的值,所以等于x++。