C语言书本上一个例题,二维数组.看不懂.!
输出二维数组中每一行的最小元素及其行列号代码{inta[5][5]={{11,22,33,42,53},{51,41,31,21,11},{44,54,24,34,74}...
输出二维数组中每一行的最小元素及其行列号
代码
{
int a[5][5]={{11,22,33,42,53},
{51,41,31,21,11},
{44,54,24,34,74},
{93,59,17,64,74},
{96,45,39,65,58}};
int i,j,col;
for(i=0;i<5;i++)
{
col=0; //找到最小的元素
for(j=0;j<5;j++)
if(a[i][j]<a[i][col])
col=j; //用变量col保存最小的元素所在的列数
printf(''row:%d,min:#d,col:%d\n'',i+1,a[i][col],col+1);
}
return 0;
}
后几个循环都能看懂, 第一个循环 i=0时, 进入循环 j=0
a[0][0]<a[0][0]不成立
j=1
a[0][1]<a[0][0] 不成立
j=2
a[0][2]<a[0][0]不成立
j=3
a[0][3]<a[0][0]不成立
j=4
a[0][4]<a[0][0]不成立
第一个循环 看上去就不成立啊, 因为 a[0]行里 最小的数在a[0][0]啊, 我哪理解错了, 展开
代码
{
int a[5][5]={{11,22,33,42,53},
{51,41,31,21,11},
{44,54,24,34,74},
{93,59,17,64,74},
{96,45,39,65,58}};
int i,j,col;
for(i=0;i<5;i++)
{
col=0; //找到最小的元素
for(j=0;j<5;j++)
if(a[i][j]<a[i][col])
col=j; //用变量col保存最小的元素所在的列数
printf(''row:%d,min:#d,col:%d\n'',i+1,a[i][col],col+1);
}
return 0;
}
后几个循环都能看懂, 第一个循环 i=0时, 进入循环 j=0
a[0][0]<a[0][0]不成立
j=1
a[0][1]<a[0][0] 不成立
j=2
a[0][2]<a[0][0]不成立
j=3
a[0][3]<a[0][0]不成立
j=4
a[0][4]<a[0][0]不成立
第一个循环 看上去就不成立啊, 因为 a[0]行里 最小的数在a[0][0]啊, 我哪理解错了, 展开
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询