杭电acm2535我哪里错了 网址http://acm.hdu.edu.cn/showproblem.php?pid=2535

#include<stdio.h>intmain(){intn,a[200],i,j,t,sum;while(scanf("%d",&n)!=EOF&&n){sum=0;... #include<stdio.h>
int main()
{
int n,a[200],i,j,t,sum;
while(scanf("%d",&n)!=EOF&&n)
{
sum=0;
for(i=1;i<=n;i++)
scanf("%d",&a[i]);
for(i=1;i<=n;i++)
{
for(j=i;j<=n-1;j++)
{
if(a[j]>a[j+1])
{
t=a[j];
a[j]=a[j+1];
a[j+1]=t;
}
}
}
n=n/2+1;
for(i=1;i<=n;i++)
sum=sum+a[i]/2+1;
printf("%d\n",sum);
}
return 0;
}
展开
 我来答
qfyh05
2011-01-24 · TA获得超过507个赞
知道小有建树答主
回答量:325
采纳率:50%
帮助的人:358万
展开全部
排序算法错了,你这个冒泡法写错了。
改为:
for(i=1;i<=n;i++)
{
for(j=1;j<=n-i;j++)
{
if(a[j]>a[j+1])
{
t=a[j];
a[j]=a[j+1];
a[j+1]=t;
}
}
}
就行了,结果能AC。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式