编写一个函数,使给定的一个3×3的二维整型数组转置,即行列互换 50

为什么执行出错说't':undeclaredidentifier#include<stdio.h>#defineN3intscore[N][N];intmain(){vo... 为什么执行出错说't' : undeclared identifier
#include<stdio.h>
#define N 3
int score[N][N];
int main()
{
void convert(int score[][3]);
int i,j;
printf("input array:\n");
for(i=0;i<N;i++)
for(j=0;j<N;j++)
scanf("%d",&score[i][j]);
for(i=0;i<N;i++)
{ for(j=0;j<N;j++)
printf("%d\t",score[i][j]);
printf("\n");
}
convert(score);
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
printf("%d\t",score[i][j]);
printf("\n");
}
return 0;
}
void convert()
{
int i,j,k;
for(i=0;i<N;i++)
for(j=i+1;j<N;j++)
{ t=array[i][j];array[i][j]=array[j][i];array[j][i]=t; }
}
展开
 我来答
刺友互
高粉答主

2019-07-04 · 每个回答都超有意思的
知道答主
回答量:3979
采纳率:100%
帮助的人:63.6万
展开全部

1、首先打开Eclipse。

2、新建一个新的Java工程。

3、新建一个Example8类文件。

4、创建2维数组。

5、创建一个输出2维数组的函数。

6、遍历数组,输出数组元素。

7、输出2维数组。

8、运行程序看看行列互换。

百度网友d585d01
推荐于2016-03-30 · TA获得超过669个赞
知道小有建树答主
回答量:339
采纳率:0%
帮助的人:463万
展开全部
#include<stdio.h>
#define N 3
int score[N][N];
int main()
{
void convert(int score[][3]);
int i,j;
printf("input array:\n");
for(i=0;i<N;i++)
for(j=0;j<N;j++)
scanf("%d",&score[i][j]);
for(i=0;i<N;i++)
{   for(j=0;j<N;j++)
printf("%d\t",score[i][j]);
printf("\n");
}
convert(score);
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
printf("%d\t",score[i][j]);
printf("\n");
}
return 0;
}
void convert(int array[][3])//注意形参
{
int i,j,t;//注意定义t而不是k
for(i=0;i<N;i++)
for(j=i+1;j<N;j++)
{ t=array[i][j];array[i][j]=array[j][i];array[j][i]=t; }
}

 

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友38a8a85
2020-03-09
知道答主
回答量:36
采纳率:0%
帮助的人:2.1万
展开全部
package com.minrisoft;public class wky { public static void main(String[] args) { int arr[][]= new int[][] { {11,22,33},{44,55,66},{77,88,99} }; System.out.println("行列互换前: "); printArray(arr); int arr2[][]= new int [arr.length][arr.length]; for (int i=0;i<arr.length;i++) { for (int j=0;j< arr[i].length;j++) { arr2[i][j]=arr[j][i]; } } System.out.println("行列互换后: "); printArray(arr2); } private static void printArray(int[][] arr) { for(int i=0;i<arr.length;i++) { for (int j = 0; j < arr.length; j++) { System.out.print(arr[j][i] + " "); } System. out .println();}}}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
鱼别丢SE
2009-06-10 · TA获得超过401个赞
知道答主
回答量:187
采纳率:0%
帮助的人:0
展开全部
有两处错误,1处语法错误,1处逻辑错误
sort(a[3][3]);修改成sort(a);就可以
但是你运行一下,你可以发现他没有转置

因为 for(i=0;i<3;i++)
for(j=0;j<3;j++)把所有的元素都循环了,例如a[1][2]对换了,然后a[2][1]也对换了,实际上没有作用了就,你可以改成for(i=0;i<3;i++)
for(j=i;j<3;j++)
这样就不会重复对换,就可以实现转置的目的了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式