#include<stdio.h>
int main()
{
for(;;)//本循环未指定循环次数,可以无限循环
{
int n,i,j;
printf("Please enter n:\n");
scanf("%d",&n);
struct item
{
int Wi;
int Pi;
}a[n],t;
printf("Please enter mass and amount:\n");
for(i=0;i<n;i++)
{
scanf("%d %d",&a[i].Wi,&a[i].Pi);
}
for(i=0;i<n-1;i++)
{
for(j=0;j<n-i-1;j++)
{
if(a[j].Wi>a[j+1].Wi)
{
t=a[j];
a[j]=a[j+1];
a[j+1]=t;
}
}
}
printf("The array of mass rising is: \n");
for(i=0;i<n;i++)
{
printf("%dg %dyuan\n",a[i].Wi,a[i].Pi);
}
}
return 0;
}
已经编好按质量升序排序的代码,我想在if里面套if来实现质量相同按价格降序,但是程序运行结果出现错误。试问该在哪里加上什么样的代码实现质量相同按价格降序?
修改如下,供参考:
#include<stdio.h>
int main()
{
for(;;)//本循环未指定循环次数,可以无限循环
{
int n,i,j;
printf("Please enter n:\n");
scanf("%d",&n);
struct item
{
int Wi;
int Pi;
}a[10],t;
printf("Please enter mass and amount:\n");
for(i=0;i<n;i++)
{
scanf("%d %d",&a[i].Wi,&a[i].Pi);
}
for(i=0;i<n-1;i++)
{
for(j=0;j<n-i-1;j++)
{
if(a[j].Wi>a[j+1].Wi)
{
t=a[j];a[j]=a[j+1];a[j+1]=t;
}
else if(a[j].Wi == a[j+1].Wi && a[j].Pi < a[j+1].Pi)
{
t=a[j];a[j]=a[j+1];a[j+1]=t;
}
}
}
printf("The array of mass rising is: \n");
for(i=0;i<n;i++)
{
printf("%dg %dyuan\n",a[i].Wi,a[i].Pi);
}
}
return 0;
}