第四周《C语言及程序设计》实践项目32 二维数组及其定义

Posted weixin_35827498

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第四周《C语言及程序设计》实践项目32 二维数组及其定义相关的知识,希望对你有一定的参考价值。

【项目1-折腾二维数组】

/*  
 * Copyright (c) 2016, CSDN学院  
 * All rights reserved.  
 * 文件名称:【项目1-折腾二维数组】.cpp  
 * 作    者:张易安  
 * 完成日期:2016年 9 月 13 日  
 * 版 本 号:v1.0  
 *  
 * 问题描述:创建一个5行4列的二维整型数组,通过初始化,为数组中的前两列的10个元素赋初值,然后:
 *通过键盘输入,使后两列的10个元素获得值;
 *按行序优先输出数组元素;
 *将所有元素值乘以3后保存在数组中;
 *按列序优先输出(输出的第一行是数组中的第一列……,其实输出的就是“转置”);
 *将数组“倒”着输出(即最后一行最后一列的最先输出,第0行第0列的最后输出);
 *输出数组中的所有偶数;
 *输出所有行列下标之和为3的倍数的元素值。
 */
#include<stdio.h>
int main()

	int i,j;
	int a[5][4] = 0,1,4,5,8,9,12,13,16,17;
	printf("请输入10个整数:\\n");
	for(i=0;i<5;i++)
	  for(j=2;j<4;j++)
      scanf("%d",&a[i][j]);
      
    printf("数组中的值为:\\n");
    for(i=0;i<5;i++)
    
    	printf("第%d行: \\n",i);
      for(j=0;j<4;j++)
      
      	printf("%d\\t",a[i][j]); 
	  
	  printf("\\n");
    
    
    printf("现在将所有元素乘以3倍...");
    for(i=0;i<5;i++)
      for(j=0;j<4;j++)
      a[i][j]=3*a[i][j];
      
    printf("行序优先输出:\\n");
    for(i=1;i<5;i++)
    
    	printf("第%d行:\\n",i);
    	for(j=0;j<4;j++)
    	
    		printf("%d\\t",a[i][j]);
		
		printf("\\n");
	
	
	printf("倒着输出:\\n");
	for(i=4;i>=0;i--)
	
		printf("第%d行:\\n",i);
        for(j=3;j>=0;j--)
        
        	printf("%d\\t",a[i][j]);
		
		printf("\\n");
    
    
    printf("数组中的偶数:\\n");
    for(i=0;i<5;i++)
    
    	printf("第%d行:\\n",i);
    	for(j=0;j<4;j++)
    	
    		if(a[i][j]%2==0)
    		printf("a[%d][%d]=%d\\n",i,j,a[i][j]);
		
		printf("\\n");
	
	
	printf("行列下标之和为3的倍数的元素:\\n");
	for(i=0;i<5;i++)
	
	   printf("第%d行:\\n",i);
	  for(j=0;j<4;j++)
	  
	  	if((i+j)%3==0)
	  	printf("a[%d][%d]=%d\\n",i,j,a[i][j]);
	  
	  printf("\\n");
    
    
    return 0;
  
 //又一次领会到了分步骤写的魅力,搭建一个大的框架,再详细补充 

运行结果



【项目2-矩阵运算】

/*  
 * Copyright (c) 2016, CSDN学院  
 * All rights reserved.  
 * 文件名称:【项目2-矩阵运算】.cpp  
 * 作    者:张易安  
 * 完成日期:2016年 9 月 13 日  
 * 版 本 号:v1.0  
 *  
 * 问题描述: 两个矩阵相加,要求其行、列数均相等。运算规则为:一个n行m列的矩阵A加上另一个n行m列的矩阵,
 * 得到的结果是一个n行m列的矩阵C,C中的第i行第j列位置上的数等于A和B矩阵第i行第j列上数相加的和。
 */
#include<stdio.h>
int main()

	int a[4][3]=1,2,3,4,5,6,7,8,9,10,11,12;
	int b[4][3]=10,20,30,40,50,60,70,80,90,100,110,120;
	int c[4][3];
	int i,j;
	
	for(i=0;i<4;i++)
	
	  for(j=0;j<3;j++)
	  
	  	  c[i][j] = a[i][j]+b[i][j];
	  	  printf("%d\\t",c[i][j]);
	    
	   printf("\\n");
    
    return 0;

运行结果


【项目2-矩阵运算】2

/*  
 * Copyright (c) 2016, CSDN学院  
 * All rights reserved.  
 * 文件名称:【项目2-矩阵运算】.cpp  
 * 作    者:张易安  
 * 完成日期:2016年 9 月 13 日  
 * 版 本 号:v1.0  
 *  
 * 问题描述: 一个n行m列的矩阵可以乘以一个m行p列的矩阵,得到的结果是一个n行p列的矩阵,
 * 其中的第i行第j列位置上的数等于前一个矩阵第i行上的m个数与后一个矩阵第j列上的m个数对应相乘后所有m个乘积的和。
  例如,下面的算式表示一个2行3列的矩阵乘以3行4列的矩阵,其结果是一个2行4列的矩阵:

  按二维数组习惯,从第0行第0列开始计数,结果中第1行第2列的元素是9,是通过左矩阵中的第1行(2  0  3),
 * 乘以右矩阵中的第2列(3  2  1),对应数相乘并加起来,就得到了9,即2×3-0×2+3×1=9。请将这个矩阵乘手工计算一下,规则不复杂。
  请编程序,实现两个矩阵的乘法。
 */
#include<stdio.h>
int main()

	int a[2][3] =1,1,0,2,0,3,b[3][4] = 0,2,3,1,1,0,2,2,2,1,1,1,c[2][4];
	int i,j,k,s;
	for(i=0;i<2;i++)
	  for(j=0;j<4;j++)
	  
	  	s=0;
	  	for(k=0;k<3;k++)
	  	  s = s + a[i][k]*b[k][j];
	  	c[i][j] = s;
	  
	for(i=0;i<2;i++)
	
		for(j=0;j<4;j++)
		  printf("%6d",c[i][j]);
		printf("\\n");
	
	
	return 0;
  

运行结果



以上是关于第四周《C语言及程序设计》实践项目32 二维数组及其定义的主要内容,如果未能解决你的问题,请参考以下文章

第四周《C语言及程序设计》实践项目39 动态存储管理与动态数组的实现

第四周《C语言及程序设计》实践项目39 动态存储管理与动态数组的实现

第四周《C语言及程序设计》实践项目16 数组的引入

第四周《C语言及程序设计》实践项目37 操作字符串数组

第四周《C语言及程序设计》实践项目37 操作字符串数组

第四周《C语言及程序设计》实践项目22 用指针法访问数组元素