C语言作业六
1.
关于数组初始化,下列说法不正确的是:
A. ⼆维数组初始化的时候,列数是必须给出的,⾏数可以由编译器来数。
B. ⼆维数组初始化的时候,每⾏⼀个{},逗号分隔。
C. 对⼀维数组初始化的时候,即使给全部元素都赋了初值,也不能省略数组⻓度
D. ⼆维数组初始化的时候,最后的逗号可以存在
答案:D
2.
不正确的赋值或赋初值的⽅式是____。请附上解释。
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
在C语言中,不能在初始化后直接对整个数组赋值
3.
若⼆维数组 a 有 m 列,则在 a[i][j] 前的元素个数为( ).
A. i * m + j + 1
B. j * m + i
C. i * m + j
D. j * m + i + 1
答案:D
4.
下列程序段中能完成数组中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
5.
题⽬:有以下程序,程序运⾏后的输出结果是( )。需附上简要解释。
#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循环中,i代表着行j代表着列。先输入i行中的第j列
6.
#include <stdio.h>
int pick_min(int arr[],int len){
int min = arr[0];
for(int i = 0;i < 0;i++ ){
if(min < arr[i]){
min = arr[i];
}
}
return min;
}
int main (){
int arr[]={1,2,4,5,7,9,10,11};
int len = sizeof(arr)/sizeof(arr[0]);
printf("%d",pick_min(arr,len));
return 0;
}
7.
#include <stdio.h>
void f(double arr[],int len){
int temp = 0;
for(int i =0;i < len;i++ ){
for(int j = 0;j < len ;j++ ){
if(arr[j] > arr[i] ){
temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
}
}
int main (){
double arr[]={9,8,7,6,5,10,3,2,1};
int len = sizeof(arr)/sizeof(arr[0]);
f(arr,len);
for(int i=0;i < len;i++ ){
printf("%f",arr[i]);
}
return 0;
}
8.
题⽬:输⼊⼀个⼆维数组的⾏数 m(m≤10),列数 n(n≤10),⼆维数组的各元素
值。输出周边元素之和。
说明:「周边元素是指⾸⾏、⾸列、末⾏、末列的数组元素」
输⼊⽰例:3⾏4列,后接具体的3⾏4列数组。
#include <stdio.h>
#include <string.h>
int main (){
int m=0,n=0;
scanf("%d %d",&m,&n);
if( (m < 0 || m > 10) || (n < 0 || n > 10 ) ){
return 0;
}
int cell[m][n];
for(int i = 0;i < m;i++ ){
for(int j = 0;j < n;j++ ){
cell[i][j] = 0;
}
}
for(int i = 0;i < m;i++ ){
for(int j = 0;j < n;j++ ){
scanf("%d",&cell[i][j]);
}
}
int sum = 0;
for(int i=0;i < m;i++ ){
for(int j=0;j < n;j++ ){
if(i=0 || j=0 || i=m-1 || j=n-1 ){
sum += cell[i][j];
}
}
}
printf("%d",sum);
return 0;
}

浙公网安备 33010602011771号