一道C++编程题,求高手解决下~

题目:某大学开田径运动会,现有12名选手参加100米比赛,对应的运动员号及成绩如表所示,请按照成绩排名并输出,要求每一行输出名次、运动员号及成绩,参见程序运行结果。要求用... 题目:某大学开田径运动会,现有12名选手参加 100米 比赛,对应的运动员号及成绩如表所示,请按照成绩排名并输出,要求每一行输出名次、运动员号及成绩,参见程序运行结果。要求用冒泡法排序。
运动员号 成绩(秒) 运动员号 成绩(秒)
001 13.6 031 14.9
002 14.8 036 12.6
010 12.0 037 13.4
011 12.7 102 12.5
023 15.6 325 15.3
025 13.4 438 12.7
程序运行结果:
名次 编号 成绩
1 010 12
2 102 12.5
3 036 12.6
4 011 12.7
5 438 12.7
6 025 13.4
7 037 13.4
8 001 13.6
9 002 14.8
10 031 14.9
11 325 15.3
12 023 15.6

希望高手能给出能运行的完整代码,在下想学习下~
展开
 我来答
businiaowyf
2009-12-25 · TA获得超过205个赞
知道小有建树答主
回答量:276
采纳率:0%
帮助的人:303万
展开全部
完全符合你的要求,哪不懂随时hi我~ok?
#include<iostream>
#include<stdio.h>
using namespace std;
#define NUM 12
struct Ath
{
int no;//名次
char s[3];//编号
float perf;//成绩
}ath[NUM];

void seque(Ath a[NUM])//冒泡排序函数
{
Ath tmp;
int n=12;
for(int k=0;k<12;k++)//计数用
{

for(int j=0;j<11-k;j++)
if(a[j].perf>a[j+1].perf)
{
tmp=a[j+1];
a[j+1]=a[j];
a[j]=tmp;
}
a[n-1].no=n;//给每个运动员排定名次
n--;
}
//return a[NUM];
}

void main()
{
for(int i=0;i<12;i++)//输入运动员信息
{
cout<<"请输入第"<<i+1<<"运动员的信息:(编号 成绩)"<<endl;
cin>>ath[i].s>>ath[i].perf;
}
seque(ath);
cout<<"名次\t"<<"编号\t"<<"成绩\t"<<endl;//排序后输出
for(int m=0;m<12;m++)
cout<<ath[m].no<<"\t"<<ath[m].s<<"\t"<<ath[m].perf<<endl;
}
csq527
2009-12-25
知道答主
回答量:25
采纳率:0%
帮助的人:25.4万
展开全部
#include <iostream>
#include <iomanip>
using namespace std;

struct Players
{
int num;
float score;
};

int main()
{
Players member[12] = {{001, 13.6}, {002, 14.8},
{010, 12.0}, {011, 12.7},
{023, 15.6}, {025, 13.4},
{031, 14.9}, {036, 12.6},
{037, 13.4}, {102, 12.5},
{325, 15.3}, {438, 12.7}
};
int temp_N;
float temp_S;

//Bubble Sort
for(int i=0; i<12; ++i)
{
for(int j=0; j<12-i; ++j)
{
if(member[j].score > member[j+1].score)
{
temp_N = member[j+1].num;
temp_S = member[j+1].score;
member[j+1].num = member[j].num;
member[j+1].score = member[j].score;
member[j].num = temp_N;
member[j].score = temp_S;
}
}
}

cout << setiosflags(ios::left) << setw(6) << "名次" << setw(6) << "号码" << setw(6) << "成绩" << endl;
for(int i=0; i<12; ++i)
{
cout << setiosflags(ios::left) << setiosflags(ios::fixed) << setprecision(1)
<< setw(6) << setw(6) << i+1 << setw(6) << member[i].num << setw(6) << member[i].score << endl;
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
hm_anwei
2009-12-25 · TA获得超过193个赞
知道小有建树答主
回答量:307
采纳率:100%
帮助的人:337万
展开全部
class Sporter
{
friend class Comption;
public:
int number;
float sorce;

Comption(int num,float sor)
{

}
};
class Comption
{
public:
Sporter spo[12];
Sporter temp;

void Init()
{
spo[0].Comption(001,13.6);
spo[1].Comption(002,14.8);
spo[2].Comption(010,12.0);
spo[3].Comption(011,12.7);
spo[4].Comption(023,15.6);
spo[5].Comption(025,13.4);
spo[6].Comption(031,14.9);
spo[7].Comption(036,12.6);
spo[8].Comption(037,13.4);
spo[9].Comption(102,12.5);
spo[10].Comption(325,15.3);
spo[11].Comption(438,12.7);

}

void Swap(Sporter &sp1,Spoter &sp2)
{
temp.number=sp1.number;
temp.sorce=sp1.sorce;

sp1.number=sp2.number;
sp1.sorce=sp2.sorce;

sp2.number=temp.number;
sp2.sorce=sp2.sorce;
}

void PaiXu()
{
for(int i=0;i<12;i++)
{
for(int j=i+1;j<12;j++)
{
if(spo[i]>spo[j])
this.Swap(spo[i],spo[j])
}
}
};

void Show()
{
for(int i=0;i<12;i++)
{
cout>>"NO.">>i+1>>"\tNumbers:">>spo[i].number>>"\tTime:">>spo[i].sorce>>end;
}
}

};

void main()
{
Competion com;
com.Init();
com.PaiXu();
com.Show();
}

//正在安装VS2008
//在记事本里面打的 所以没有调试
//但是逻辑应该没有问题
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
林声飘扬
2009-12-26 · TA获得超过1630个赞
知道小有建树答主
回答量:1126
采纳率:50%
帮助的人:966万
展开全部
#include <iostream>
#include <string>
struct Player
{
string num ;
float score;
};

void Sort(Player a[]);

int main()
{
Player stud[6]; //定义结构体数组stud,有12个元素;

for(int i=0;i<6;++i) //给数组元素赋值
{
cout<<" \n运动员号:";
cin>>stud[i].num;
cout<<" \n成绩:";
cin>>stud[i].score;

}

Sort(stud);
int i=6 ;
for(int j=0;j<6;++j)
{
cout<<"\n第"<<i<<"名是:"<<stud[j].num<<" 成绩为:"<<stud[j].score;
i--;
}

return 0;
}

void Sort(Player a[])
{
Player temp;
int i,j;
for(i=0;i<6;i++)
for(j=0;j<6;++j)
{ if(a[j].score<a[j+1].score)
{
temp=a[j+1];
a[j+1]=a[j];
a[j]=temp;
}
}

}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式