C基础补习测试题
一、选择题(每题2分,共 50 分)
- C语言中,运算对象必须是整型数的运算符是 A 。
A、% B、/ C、%和/ D、*
- 若有关系x≥y≥z,应使用 A C语言表达式。
A、(x>=y)&&(y>=z) B、(x>=y)AND(y>=z) C、(x>=y>=z) D、(x>=y)&(y>=z)
- 下面程序的输出是 C main( ) { int x=10,y=3; printf(“%d\n”,y=x/y);
}
A、0 B、1 C、3 D、不确定的值
- 若float x ;x = 10/4 ; x的值是 B 。
A、2.5 B、 2.0 C、 3 D、 2
- 设有以下语句:int a=3,b=6,c; c=a^b<<2; 则c的二进制值是 C 。
A、00011011 B、00010100 C、00011100 D、00011000
- 在位运算中,某操作数 右移3位,其结果相当于 D A、操作数乘以6 B、操作数除以6 C、操作数乘以8 D、操作数除以8
- 表达式 !x 等价于 A 。
A、x==0 B、x==1 C、x != 0 D、x != 1
- 下列语句定义pf为指向float类型变量f的指针, B 是正确的。
- float f, *pf=f; B、float f, *pf=&f; C、float *pf=&f, f; D、float f, pf=f;
- 执行下列程序段后,变量a,b,c的值分别是 D 。
int x=10,y=9;
int a,b,c;
a=(--x==y++)?--x:++y;
b=x++;
c=y;
A、a=9,b=9,c=9 B、a=9,b=10,c=9 C、a=1,b=11,c=10 D、a=8,b=8,c=10
- 整型变量x和y的值相等,且为非0值,则以下选项中,结果为0的表达式是 D 。
A、x || y B、x | y C、x & y D、x ^ y
- 对两个数组a和b进行如下初始化
char a[]=“ABCDEF”; char b[]={ ‘A’,’B’,’C’,’D’,’E’,’F’};
则以下叙述正确的是 D 。
A、a和b数组完全相同 B、a和b长度相同
C、a和b中都存放字符串 D、a数组比b数组长度长
- 设变量定义为“int x, *p=&x;”,则&*p相当于 C 。
A、p B、*p C、x D、*&x
- 若已定义 char s[10]; 则在下面表达式中不表示s[1]的地址的是 B 。
A、s+1 B、 s++ C、&s[0]+1 D、 &s[1]
- 以下程序的执行结果为 A 。
#inlcude <stdio.h>
#define N 2
#define M N+1
#define NUM (M+1)*M/2
main()
{pirntf("%d",NUM);} A、5 B、6 C、8 D、9
- 以下程序的输出结果是 A 。
#define M(x,y,z) x*y+z
main()
{ int a=1,b=2, c=3;
printf("%d\n", M(a+b,b+c, c+a)); } A、19 B、17 C、15 D、12
- int a[5][4], *p=a[0];,则*(p+2*4+3)等于 D 。
A、a[2][0] B、a[2][1] C、a[2][2] D、a[2][3]
- int a[5][4], (*p)[4]=a;,数组a的首地址为100,*(p+2)+3等于 D 。
A、116 B、118 C、144 D、122
- int a[]={1,3,5,7,9},*p=a;,则值为5的表达式是 A 。
A、p+=2, *p++ B、p+=2, *++p C、p+=2, (*p)++ D、a+=2, *a
- 已知:char s[4] = "cba"; char *p; 执行语句序列p = s;printf("%c\n",*p+1);后,其输出为 D 。
A、字符’c’ B、字符’b’ C、字符’a’ D、字符’d’
- 已有定义 int k=2; int *ptr1, *ptr2, 且ptr1和ptr2均已指向变量k , 下面不能执行的赋值语句是 A
A、k=*ptr1+*ptr2; B、ptr2=k;
C、ptr1=ptr2; D、k=*ptr1*(*ptr2);
- 若有定义int i=2,a[10],*p=&a[i];则与*p++ 等价的是 A 。
A、a[i++] B、a[i]++ C、a[i] D、a[++i]
- 以下对二维数组a的正确说明是 D 。
A、 int a[ ][3]={ 0 }; B、int a[3][ ]={ {1},{2},{3} };
C、 int a[1][3]={ 1,2,3,4 }; D、int a[2][3]={ {1,2},{3,4},{5,6} };
- 以下程序的输出结果是 C 。
void main()
{ int a=5,*p1,**p2;
p1=&a,p2=&p1;
(*p1)++;
printf("%d\n",**p2);
}
A、5 B、4 C、6 D、不确定
- 设有定义“int a=3,b,*p=&a;”,则下列语句中使b不为3的语句是 B 。
A、b=*&a; B、b=*a; C、b=a; D、b=*p;
- int main(int argc, char *argv[])
{
int i, n = 0;
for (i=1; i<argc; i++) { n = 10*n + *argv[i] – ‘0’; }
printf(“%d\n”, n);
}
./aout 12 345 678
输出结果为____C_____。
A、123 B、136 C、678 D、58
二、程序题(每题5分,共50分)
1.已知两个升序数组a、b及空数组c:
Int a[] = {1,3,5,7,9,11,13,15,17,19};
Int b[] = {2,4,6,8,10,12,14,16,18,20};
Int c[20];
编写程序将两个数组完成归并,并存入数组c中;
#include <stdio.h>
int main() {
int a[] = {1, 3, 5, 7, 9, 11, 13, 15, 17, 19};
int size_a = sizeof(a) / sizeof(a[0]);
int b[] = {2, 4, 6, 8, 10, 12, 14, 16, 18, 20};
int size_b = sizeof(b) / sizeof(b[0]);
int c[20];
int i = 0, j = 0, k = 0;
// 归并两个数组
while (i < size_a && j < size_b) {
if (a[i] <= b[j]) {
c[k++] = a[i++];
} else {
c[k++] = b[j++];
}
}
// 处理剩余元素
while (i < size_a) {
c[k++] = a[i++];
}
while (j < size_b) {
c[k++] = b[j++];
}
// 打印归并后的数组 c
printf("Merged Array (c): ");
for (int x = 0; x < size_a + size_b; x++) {
printf("%d ", c[x]);
}
return 0;
}
2. 编写strcat函数(不调用C的字符串库函数,编写函数 strcat).
已知strcat函数的原型是 char *strcat(char *strDest, const char *strSrc);
strDest是目的字符串,strSrc是源串。
#include <stdio.h>
char *my_strcat(char *strDest, const char *strSrc) {
char *p = strDest;
// 将指针移动到目的字符串的末尾
while (*p != '\0') {
p++;
}
// 复制源字符串到目的字符串末尾
while (*strSrc != '\0') {
*p = *strSrc;
p++;
strSrc++;
}
// 在目的字符串末尾添加 null 字符
*p = '\0';
return strDest;
}
int main() {
char strDest[20] = "Hello, ";
const char strSrc[] = "world!";
// 调用自定义的 strcat 函数
my_strcat(strDest, strSrc);
// 打印结果
printf("Concatenated String: %s\n", strDest);
return 0;
}
3.一个岔路口分别通向诚实国和说谎国。来了两个人,已知一个是诚实国的,另一个是说谎国的。诚实国永远说实话,说谎国永远说谎话。现在你要去说谎国,但不知道应该走哪条路,需要问这两个人。请问应该怎么问?
无论你问哪一个,他们都会指向通向诚实国的路。因此,你应该选择相反的路,即他们所指的另一条路,这样就能到达说谎国。
4. 从键盘输入一个十个元素的数组,通过选择排序进行降序排列并输出结果
#include <stdio.h>
int main() {
int arr[10];
int i, j, maxIndex, temp;
// 输入十个元素的数组
printf("Enter 10 elements of the array:\n");
for (i = 0; i < 10; i++) {
scanf("%d", &arr[i]);
}
// 选择排序逻辑
for (i = 0; i < 10 - 1; i++) {
maxIndex = i;
// 在未排序部分找到最大元素的索引
for (j = i + 1; j < 10; j++) {
if (arr[j] > arr[maxIndex]) {
maxIndex = j;
}
}
// 交换找到的最大元素与未排序部分的第一个元素
temp = arr[i];
arr[i] = arr[maxIndex];
arr[maxIndex] = temp;
}
// 输出降序排列后的数组
printf("Sorted array in descending order:\n");
for (i = 0; i < 10; i++) {
printf("%d ", arr[i]);
}
return 0;
}
5. 给定一个字符串“I love china”,编写程序完成以单词为单位的逆序,如“china love i”,并要求不允许使用第三方变量保存数据,但可以使用辅助指针变量等。
#include <stdio.h>
#include <string.h>
int main() {
char str[] = "I love china";
// 逆序整个字符串
int len = strlen(str);
char *start = str;
char *end = str + len - 1;
while (start < end) {
char temp = *start;
*start = *end;
*end = temp;
start++;
end--;
}
// 逆序每个单词
start = str;
while (*start) {
// 找到单词的开始和结束位置
while (*start && *start == ' ') {
start++;
}
char *wordStart = start;
while (*start && *start != ' ') {
start++;
}
char *wordEnd = start - 1;
// 逆序单词
while (wordStart < wordEnd) {
char temp = *wordStart;
*wordStart = *wordEnd;
*wordEnd = temp;
wordStart++;
wordEnd--;
}
}
// 输出结果
printf("Reversed String: %s\n", str);
return 0;
}