第四周《C语言及程序设计》实践项目32 二维数组及其定义
2016-09-13 19:05
344 查看
【项目1-折腾二维数组】
运行结果
![](http://img.blog.csdn.net/20160913153214187)
【项目2-矩阵运算】
运行结果
![](http://img.blog.csdn.net/20160913153528769)
【项目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;
}
运行结果
/* * 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语言及程序设计》实践项目20 经典:查找的艺术
- 第四周《C语言及程序设计》实践项目5 认识递归
- 第四周《C语言及程序设计》实践项目2 模块化程序设计及C语言中的函数
- 《C语言及程序设计》实践项目——二维数组
- 第二周《C语言及程序设计》实践项目32 循环思想启蒙:输出小星星
- 《C语言及程序设计》实践项目——指针及其运算
- 《C语言及程序设计》实践项目——二维数组与指针
- 第1周 《C语言及程序设计》实践项目1——指针及其运算
- 《C语言及程序设计》实践项目——循环控制结构流程图
- 《C语言及程序设计》实践参考——字母及其编码
- 《C语言及程序设计》实践项目——函数应用
- 《C语言及程序设计》实践项目——三种循环语句
- 《C语言及程序设计》实践项目——循环嵌套
- 《C语言及程序设计》实践项目——数据的输出
- 《C语言及程序设计》实践项目——穷举法解题
- 《C语言及程序设计》实践项目——发现Bug
- C语言及程序设计.第十九课.项目1.字母及其编码
- 《C语言及程序设计》实践项目——用if语句实现分支结构
- 《C语言及程序设计》实践项目——用break和continue改变流程
- 《C语言及程序设计》实践项目——数据的输出