#include<stdio.h> void main() { char a[]="abc

#include<stdio.h>voidmain(){chara[]="abcdefg",t;inti,j=0;for(i=1;i<7;i++)if(a[j]<a[i]... #include<stdio.h>
void main()
{
char a[]="abcdefg",t;
int i,j=0;
for(i=1;i<7;i++)
if(a[j]<a[i]) j=i;
t=a[j];a[j]=a[0];a[0]=t;
puts(a);
}
if语句怎么理解?
展开
 我来答
cdyzxy
2013-12-06 · TA获得超过2.1万个赞
知道大有可为答主
回答量:1.4万
采纳率:84%
帮助的人:3546万
展开全部
如果发现数组中有比a[j]还大的数则用j记录下它的下标
程序是这样干活的:
先用记录下0,暂时算a[j]=a[0]是最大值,然后让下标i从1循环到数组结束,每次a[j]跟a[i]比,如果发现a[i]大则将i值赋值给j,这样实现数组中最大的值的下标用j来记录的目的,最后用中间变量t将最大值a[j]与a[0]值互换。
这个程序实现将指定数组中最大字符交换到数组首字符后打印输出。
追问
还想问一下,把for语句里面的i++提出来,应该放哪?我现在不知道它那个是怎么进行执行?你可以写上执行一两次循环的过程。麻烦你了
追答
for ( i=1;i<7;i++ ) if ( a[j]<a[i] ) j=i;
相当于
i=1;
LOOP:
if ( i<7 )
{ if ( a[j]<a[i] ) j=i;
i++;
goto LOOP;

}
空雪梦见
2013-12-06 · TA获得超过5596个赞
知道大有可为答主
回答量:2522
采纳率:75%
帮助的人:1138万
展开全部
j里保存的是“我认为当前最大的是a[j]”这样的意思
一旦发现有其他比a[j]更大(if),就让j等于这个更大的元素的下标
一圈下来,j就真的是“最大元素的下标”了
然后把最大元素和a[0]互换。

整个程序的作用是把这里面最大的元素和第一个元素互换。
执行结果应该是gbcdefa(未实际运行验证
追问
谢谢!
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2013-12-06
展开全部
#include<stdio.h>
void main()
{
   char a[]="abcdefg",t;
   int i,j=0;
   for(i=1;i<7;i++)
   {              //大括号最好还是要滴
        if(a[j]<a[i]) 
/*如果满足条件a[j]<a[i],就执行后面那段{...},
否则跳过,继续下一步循环*/
{
j=i;
t=a[j];
a[j]=a[0];
a[0]=t;
}
   }

   puts(a);
}
更多追问追答
追问
谢谢!
还想问一下,如果把for语句里面的i++提出来,应该放哪?我现在不知道它那个是怎么进行执行?你可以写上执行一两次循环的过程。麻烦你了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
冰清258
2013-12-06 · TA获得超过443个赞
知道小有建树答主
回答量:260
采纳率:0%
帮助的人:38.7万
展开全部
gfedcba if是让ab bc cd de ef fg依次比较大小然后互换
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
尚羽莜
2013-12-05 · TA获得超过281个赞
知道答主
回答量:162
采纳率:0%
帮助的人:64万
展开全部
你这是C语言么?
追问
追答
啊!你厉害!我Loge学完就停止了,抱歉帮不上忙……T^T
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 3条折叠回答
收起 更多回答(5)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式