scanf输入整型数组⼆维数组的简单使⽤及其运算
3、下⾯程序的功能是将⼆维数组a中每个元素向右移⼀列,最右⼀列换到最左⼀列,移后的结果保存到b数组中,并按矩阵形式输出a和b。请填空使程序完整。
数组a如下:
4 5 6
1 2 3
移完后的数组b如下
6 4 5
3 1 2
解答:
/*
*Copyright (c) 2016, CSDN学院
*All rights reserved.
*⽂件名:main.c
*作者:DylanLiu
*完成⽇期:2016/12/02
*版本号:V1.0
*
*问题描述:⼀个⾏列式的简单移项。
*程序输出:⾏列式的列都左移⼀位(最后⼀列移到第⼀位)的输出。
*/
#include <stdio.h>
int main( )
{
int a[2][3]={{4,5,6},{1,2,3}}, b[2][3], i,j;
//输出a
for (i=0; i<2 ; i++)
{
for (j=0; j<3; j++ )
{
printf("%5d",a[i][j]);
}
printf("\n");
}
printf("\n");
//a中元素右移得到b
for (i=0; i<2 ; i++)
for (j=0; j<3 ; j++ )
b[i][j]=a[i][(j+2)%3];
//输出b
for (i=0; i<2; i++)
{
for (j=0; j<3 ; j++)
{
printf("%5d",b[i][j]);
}
printf("\n");
}
return0;
}
输出结果:
任务和代码:
【项⽬1-折腾⼆维数组】
创建⼀个5⾏4列的⼆维整型数组,通过初始化,为数组中的前两列的10个元素赋初值,然后: 通过键盘输⼊,使后两列的10个元素获得值;
按⾏序优先输出数组元素;
将所有元素值乘以3后保存在数组中;
按列序优先输出(输出的第⼀⾏是数组中的第⼀列……,其实输出的就是“转置”);
将数组“倒”着输出(即最后⼀⾏最后⼀列的最先输出,第0⾏第0列的最后输出);
输出数组中的所有偶数;
输出所有⾏列下标之和为3的倍数的元素值。
/*
*Copyright (c) 2016, CSDN学院
*All rights reserved.
*⽂件名:main.c
*作者:DylanLiu
*完成⽇期:2016/12/02
*版本号:V1.0
*
*问题描述:⼆维数组之间的简单操作。
*程序输出:。
*/
#include <stdio.h>
int main( )
{
int i,j;
/
/创建数组,为数组中的前两列的10个元素赋初值
int a[5][4]= {{0,1},{4,5},{8,9},{12,13},{16,17}};
//键盘输⼊后两列10个元素的值
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++){
for(j=0; j<4; j++)
printf("%d  ", a[i][j]);
printf("\n");
}
//将所有元素值乘以3后保存在数组中
printf("现在将所有元素乘以3倍...");
for(i=0; i<5; i++){
for(j=0; j<4; j++)
a[i][j]=3 * a[i][j];
a[i][j]=3 * a[i][j];
}
/
/按⾏序优先输出
printf("⾏序优先输出:\n");
for(i=0; i<5; i++){
for(j=0; j<4; j++)
printf("%d  ", a[i][j]);
printf("\n");
}
//按列序优先输出(见题⽬描述)
printf("列序优先输出:\n");
for(j=0; j<4; j++){
for(i=0; i<5; i++)
printf("%d  ", a[i][j]);
printf("\n");
}
//将数组“倒”着输出(见题⽬描述)
printf("倒着输出:\n");
for(i=4; i>=0; i--){
for(j=3; j>=0; j--)
printf("%d  ", a[i][j]);
printf("\n");
}
//输出数组中的所有偶数
printf("数组中的偶数:\n");
for(i=0; i<5; i++){
for(j=0; j<4; j++){
if(a[i][j]%2==0)
printf("a[%d][%d]=%d  ",i, j, a[i][j]);
}
printf("\n");
}
//输出所有⾏列下标之和为3的倍数的元素值
printf("⾏列下标之和为3的倍数的元素:\n");
for(i=0; i<5; i++){
for(j=0; j<4; j++){
if((i+j)%3==0)
printf("a[%d][%d]=%d  ", i, j, a[i][j]);
}
printf("\n");
}
return0;
}
输出结果:
任务和代码:
【项⽬2-矩阵运算】
  在数学中,⼀个矩阵由若⼲⾏和若⼲列数据组成,可以直接存储为⼀个⼆维数组。
(1)矩阵相加
  两个矩阵相加,要求其⾏、列数均相等。运算规则为:⼀个n⾏m列的矩阵A加上另⼀个n⾏m列的矩阵,得到的结果是⼀个n⾏m列的矩阵C,C中的第i⾏第j列位置上的数等于A和B矩阵第i⾏第j列上数相加的和。例如:
请编程序,实现两个矩阵的加法。
/*
*Copyright (c) 2016, CSDN学院
*All rights reserved.
*⽂件名:main.c
*作者:DylanLiu
*完成⽇期:2016/12/02
*版本号:V1.0
*
*问题描述:两个矩阵相加。
*程序输出:相加之后的矩阵。
*/
#include <stdio.h>
#include <stdlib.h>
#define M 3
#define N 4
int main(void)
{
int a[N][M]={0};
int b[N][M]={0};
int c[N][M]={0};
int i=0, j=0;
printf("输⼊第⼀个矩阵(以⾏优先的形式输⼊):\n");
for(i=0; i<N; i++){
for(j=0; j<M; j++)
scanf("%d", &a[i][j]);
}
printf("第⼀个矩阵输⼊成功!\n");
printf("输⼊第⼆个矩阵(以⾏优先的形式输⼊):\n");
for(i=0; i<N; i++){
for(j=0; j<M; j++)
scanf("%d", &b[i][j]);
}
printf("两个矩阵相加之后:\n");
for(i=0; i<N; i++){
for(j=0; j<M; j++)
c[i][j]=a[i][j]+b[i][j];//两个矩阵的对应项相加
}
//输出相加之后的矩阵
for(i=0; i<N; i++){
for(j=0; j<M; j++)
printf("%d  ", c[i][j]);
printf("\n");
}
return0;
}
输出结果:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。