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;
}

 

posted @ 2023-12-09 01:00  Aeside  阅读(55)  评论(0)    收藏  举报