题目一
关于数组初始化,下列说法不正确的是:
A. ⼆维数组初始化的时候,列数是必须给出的,⾏数可以由编译器来数。
B. ⼆维数组初始化的时候,每⾏⼀个{},逗号分隔。
C. 对⼀维数组初始化的时候,即使给全部元素都赋了初值,也不能省略数组⻓度
D. ⼆维数组初始化的时候,最后的逗号可以存在
C、
一维数组初始化的时候,可以省略数组长度,编译器会根据初始化值的个数自动计算数组长度。
题目二
不正确的赋值或赋初值的⽅式是_____。请附上解释。
A. char str[] = "string";
B. char str[7] = {'s', 't', 'r', 'i', 'n', 'g'};
C. char str[10]; str = "string";
D. char str[7] = {'s', 't', 'r', 'i', 'n', 'g', '\0’};
c,数组在定义后就不能整体赋值,只能定义时进行整体赋值
题目三
若⼆维数组a有m列,则在a[ i ][ j ]前的元素个数为( ).
A. i * m + j + 1
B. j * m + i
C. i * m + j
D. j * m + i + 1
c,最开始的元素为a【0】【0】,所以有(i-0)* m+(j-0)个元素
画个图带入一下就好了
题目四
下列程序段中能完成数组中n个元素前后倒置的是( )。如数组元素为3,1,8时,完成倒置后变为8,1,3 。
A.for(i=0, j=n-1; i<j; i++, j–){ x = a[i]; a[i] = a[j]; a[j] = x;}
B.for(i=0; i<n/2; i++) { a[i] = a[n-1-i]; a[n-1-i] = a[i];}
C.for(i=0; i<n/2; i++) { x = a[i]; a[i] = a[n-1-i]; a[n-1-i] = x;}
D.for(i=0; i<n; i++) { x = a[i]; a[i] = a[n-1-i]; a[n-1-i]= x;}
看不懂,蒙个c
题目五
题⽬:有以下程序,程序运⾏后的输出结果是()。需附上简要解释。
#include <stdio.h>
int main()
{
int i, j;
int a[3][2] = {1, 2, 3, 4, 5, 6};
for (i = 0; i < 2; i++)
{
for (j = 0; j < 3; j++)
{
printf("%d\t", a[i][j]);
}
printf("\n");
}
return 0;
}
解:总共六个元素,分别为
1,2
3,4
5,6
然后for循环让行列对调
即1,2,3
4,5,6
题目六
仿照ppt计算最低分
省流:出大问题
题目七
使用数组加函数,对十个double类型数值进行从小到大排序
#include <stdio.h>
void swap(double *a, double *b) {
double temp = *a;
*a = *b;
*b = temp;
}
void sort(double arr[], int n) {
int i, j;
for (i = 0; i < n - 1; i++) {
for (j = i + 1; j < n; j++) {
if (arr[i] > arr[j]) {
swap(&arr[i], &arr[j]);
}
}
}
}
int main() {
double arr[10] = {3.2, 1.5, 7.8, 2.4, 9.1, 5.6, 4.3, 6.7, 0.9, 8.0};
int i;
printf("Original array:\n");
for (i = 0; i < 10; i++) {
printf("%.1f ", arr[i]);
}
printf("\n");
sort(arr, 10);
printf("Sorted array:\n");
for (i = 0; i < 10; i++) {
printf("%.1f ", arr[i]);
}
printf("\n");
return 0;
}