大一上C语言错题集

2023-11-01 02:59
文章标签 语言 错题 大一上

本文主要是介绍大一上C语言错题集,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大一上C语言错题集

1

在这里插入图片描述
T

答案解析:定义如此。

2
在这里插入图片描述
C

答案解析:题目要求需要输入,A B D排除。

3
在这里插入图片描述
A

答案解析:字符数组需要输入单个字符,而不是字符串。

4
在这里插入图片描述
T

答案解析:C 语言规定,只能逐个引用数组元素,而不能一次引用整个数组。

5
在这里插入图片描述
F

答案解析:数组名就是一个常量指针。

6
在这里插入图片描述
F

答案解析:可以使指针自增(减)来指向不同的数组元素。

7
在这里插入图片描述
T

答案解析:定义如此。

8

在这里插入代码片冒泡法排序:本题要求将给定的n个整数从小到大排序后输出。输出时相邻数字中间用一个空格分开,行末不得有多余空格。#include <stdio.h>
# define MAXN 10int 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 <stdio.h>
# define MAXN 10int 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<stdio.h>
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++。

这篇关于大一上C语言错题集的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/320006

相关文章

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,

C语言指针入门 《C语言非常道》

C语言指针入门 《C语言非常道》 作为一个程序员,我接触 C 语言有十年了。有的朋友让我推荐 C 语言的参考书,我不敢乱推荐,尤其是国内作者写的书,往往七拼八凑,漏洞百出。 但是,李忠老师的《C语言非常道》值得一读。对了,李老师有个官网,网址是: 李忠老师官网 最棒的是,有配套的教学视频,可以试看。 试看点这里 接下来言归正传,讲解指针。以下内容很多都参考了李忠老师的《C语言非

C 语言基础之数组

文章目录 什么是数组数组变量的声明多维数组 什么是数组 数组,顾名思义,就是一组数。 假如班上有 30 个同学,让你编程统计每个人的分数,求最高分、最低分、平均分等。如果不知道数组,你只能这样写代码: int ZhangSan_score = 95;int LiSi_score = 90;......int LiuDong_score = 100;int Zhou

C 语言的基本数据类型

C 语言的基本数据类型 注:本文面向 C 语言初学者,如果你是熟手,那就不用看了。 有人问我,char、short、int、long、float、double 等这些关键字到底是什么意思,如果说他们是数据类型的话,那么为啥有这么多数据类型呢? 如果写了一句: int a; 那么执行的时候在内存中会有什么变化呢? 橡皮泥大家都玩过吧,一般你买橡皮泥的时候,店家会赠送一些模板。 上

JavaSE-易错题集-002

1. 下面有关java基本类型的默认值和取值范围,说法错误的是? A 字节型的类型默认值是0,取值范围是-2^7—2^7-1 B boolean类型默认值是false,取值范围是true\false C 字符型类型默认是0,取值范围是-2^15 —2^15-1 D long类型默认是0,取值范围是-2^63—2^63-1 答案:C 题解:注意字符型(char) char 占16位,