YTU:写一个函数,使给定的一个二维数组(3×3)转置,即行列互换
2016-03-10 19:03
621 查看
Description
写一个函数,使给定的一个二维数组(3×3)转置,即行列互换。Input
一个3x3的矩阵Output
转置后的矩阵Sample Input
1 2 3 4 5 6 7 8 9
Sample Output
1 4 7 2 5 8 3 6 9
HINT
主函数已给定如下,提交时不需要包含下述主函数/* C代码 */
int main()
{
int a[3][3];
int i,j;
for(i=0; i<3; i++)
for(j=0; j<3; j++)
scanf("%d",&a[i][j]);
zhuangzhi(a);
for(i=0; i<3; i++)
{
for(j=0; j<3; j++)
printf("%d ",a[i][j]);
printf("\n");
}
return 0;
}
/* C++代码 */
int main()
{
int a[3][3];
int i,j;
for(i=0; i<3; i++)
for(j=0; j<3; j++)
cin>>a[i][j];
zhuangzhi(a);
for(i=0; i<3; i++)
{
for(j=0; j<3; j++)
cout<<a[i][j]<<" ";
cout<<endl;
}
return 0;
}
比较简单的指针题
下面是代码:
void *zhuangzhi(int matrix[3][3])
{
for(int i=0;i<3;i++)
for(int j=0;j<i;j++)//转置矩阵就是把a[i][j]变为a[j][i],j<i可以减少步骤 比j<3要省时间
{
int t=matrix[i][j];
matrix[i][j]=matrix[j][i];
matrix[j][i]=t;
}
}
int main()
{
int a[3][3];
int i,j;
for(i=0; i<3; i++)
for(j=0; j<3; j++)
scanf("%d",&a[i][j]);
zhuangzhi(a);
for(i=0; i<3; i++)
{
for(j=0; j<3; j++)
printf("%d ",a[i][j]);
printf("\n");
}
return 0;
}
相关文章推荐
- loadrunner11 +ie8+ win7录制时启动不了ie
- 就拿胖子说事
- UVA 11525 好大好大的排列(线段树)
- javah报错找不到类android.graphics.Bitmap的异常
- 数论基础
- 1036: [ZJOI2008]树的统计Count
- 浅谈IOS KVC和KVO
- MYSQL经验积累
- java数据结构 深搜+栈
- android MediaRecorder录制音频
- [dp专题-四边形不等式优化]51nod 1022
- Java String的构造和getByte
- (笔记) MATLAB 文本的高级控制,极坐标图
- 【CodeVS 3123】 高精度练习之超大整数乘法
- Programming in Objective-C 学习笔记06 —— Preprocessor
- 【UOJ 34】多项式乘法
- 【BZOJ 3144】 [Hnoi2013]切糕
- 【BZOJ 1095】 [ZJOI2007]Hide 捉迷藏
- 【BZOJ 4016】[FJOI2014]最短路径树问题
- 【BZOJ 2152】 聪聪可可