为什么执行子函数sort后子函数display里的变量会改变呢?能不能使display里的变量不改变?
voiddisplay()/*显示数据函数*/{inti;charas;average();do{printf("\t\t\t班级学员信息列表\n");printf("\...
void display()/*显示数据函数*/
{
int i;
char as;
average();
do
{
printf("\t\t\t班级学员信息列表\n");
printf("\t编号\t姓名\t性别\t成绩1\t成绩2\t成绩3\t平均值\n");
for(i=0;i<now_no&&stu[i].name[0];i++)printf("\t%d\t%s\t%s\t%.2f\t%.2f\t%.2f\t%.2f\n",stu[i].no,stu[i].name,stu[i].sex,stu[i].score1,stu[i].score2,stu[i].score3,stu[i].ave);
printf("\t\t按任意键返回主菜单.");
fflush(stdin);
as=getch();
}
while(!as);
system("cls");
}
void sort()/*排序数据函数*/
{
struct student temp;
int i,j;
average();
for(i=1;i<now_no;i++)
{
for(j=1;j<=now_no-i;j++)
{
if(stu[j-1].ave<stu[j].ave)
{
temp=stu[j];
stu[j]=stu[j-1];
stu[j-1]=temp;
}
}
}
} 展开
{
int i;
char as;
average();
do
{
printf("\t\t\t班级学员信息列表\n");
printf("\t编号\t姓名\t性别\t成绩1\t成绩2\t成绩3\t平均值\n");
for(i=0;i<now_no&&stu[i].name[0];i++)printf("\t%d\t%s\t%s\t%.2f\t%.2f\t%.2f\t%.2f\n",stu[i].no,stu[i].name,stu[i].sex,stu[i].score1,stu[i].score2,stu[i].score3,stu[i].ave);
printf("\t\t按任意键返回主菜单.");
fflush(stdin);
as=getch();
}
while(!as);
system("cls");
}
void sort()/*排序数据函数*/
{
struct student temp;
int i,j;
average();
for(i=1;i<now_no;i++)
{
for(j=1;j<=now_no-i;j++)
{
if(stu[j-1].ave<stu[j].ave)
{
temp=stu[j];
stu[j]=stu[j-1];
stu[j-1]=temp;
}
}
}
} 展开
2个回答
展开全部
sort是按照stu[i].ave排序处理的函数,既然排序了,那么你肯定是想按排序后的结果显示。
如果不想改变顺序,可以不调用sort函数。
如果确实想调用sort,又不想display改变,那么只能定义不同的stuSort实例。
这样需要显示未排序的结果用stu,需要显示排好序的结果用stuSort。
如果不想改变顺序,可以不调用sort函数。
如果确实想调用sort,又不想display改变,那么只能定义不同的stuSort实例。
这样需要显示未排序的结果用stu,需要显示排好序的结果用stuSort。
追问
我理解意思可是不会修改,能不能帮忙把程序修改一下,今天要用。
追答
1、void main()
{
//sort();//屏蔽掉
display();
}
2、第一步:
struct student stu[row_no];
struct student stuSort[row_no];
void main()
{
//。。。您的初始化:stu
//。。。您的初始化:stuSort——(与stu相同)
sort();
display();
}
第二步:如果想显示原始顺序,将sort中所有的stu替换为stuSort;
如果想显示排序后的顺序,保持sort中内容不变。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询