在C++中怎么实现对象数组按某一属性排序?

比如分数高低,或是学号顺序一类的.再按这个顺序输出来.... 比如分数高低,或是学号顺序一类的.再按这个顺序输出来. 展开
 我来答
曉凡_C
2010-12-12 · TA获得超过477个赞
知道小有建树答主
回答量:356
采纳率:0%
帮助的人:0
展开全部
你可以在自己的对象数组中添加一个方法,比如
class student{
private:
int score;
public:
int comparable(student temp){
if(temp.score > this.score)
return -1;
else if (temp.score == this.score)
return 0;
else
return 1;
}
}

然后在比较的时候就可以根据comparable这个函数来比较大小,进行排序。
如果使用stl的sort也可以指定用这个函数返回的值来判断大小。

希望对你有所帮助。
lliiyingbo
2010-12-12
知道答主
回答量:52
采纳率:0%
帮助的人:34.5万
展开全部
查资料
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
aaqxna
2010-12-12 · TA获得超过1975个赞
知道小有建树答主
回答量:372
采纳率:100%
帮助的人:261万
展开全部
#include <iostream>

using namespace std;

void input(int *arr, int n) {
for (int i=0; i<n; ++i) {
cin >> arr[i];
}
}

void sort(int *arr, int n) {
int tmp;
for (int i=0; i<n-1; ++i) {
for (int j=i+1; j<n; ++j) {
if (arr[i] > arr[j]) {
tmp = arr[i];
arr[i] = arr[j];
arr[j] = tmp;
}
}
}
}

void output(int *arr, int n) {
for (int i=0; i<n; ++i) {
cout << arr[i] << " ";
}
cout << endl;
}

int main()
{
int arr[10];
input(arr, 10);
sort(arr, 10);
output(arr, 10);
}
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式