候选羊的编号,姓名以及票数怎么实现

  1. 选村长(cunzhang.cpp)
    【问题描述】
    青青草原的羊村村长换届,现有三位候选羊:喜羊羊,懒羊羊和美羊羊,他们的编号分别
    为 1、2、3,另有 n 位投票羊进行投票,请将投票后的三位候选羊,按照票数降序排列,若票
    数相同,则编号小的靠前。
    提示: 使用结构体及 sort 排序
    输出
    三行,每行展示一位按照票数排序后的羊的的信息,包括候选羊编号,姓名以及票数。
    【输入文件】
    文件名:cunzhang.in
    共有两行,第一行为一个大于 0 的整数 n,表示有 n 位羊参与投票。 第二行包括 n 个范
    围在 1 至 3 之间的整数,表示这 n 位羊的投票编号。(假设没有投票羊弃权)
    【输出文件】
    文件名 cunzhang.out
    三行,每行展示一位按照票数排序后的羊的的信息,包括候选羊编号,姓名以及票数。
    【样例输入 1】
    10
    3 2 1 3 2 1 3 2 1 3

【样例输出 1】
3 美羊羊 4
1 喜羊羊 3
2 懒羊羊 3

#include<stdio.h>
#include<iostream>
using namespace std;
#define MAXSIZE 1024

int orders[3]={1,2,3};
int members[3];
string names[3] ={
   "喜羊羊""懒羊羊","美羊羊"
};
int main()
{
    int n,t;
    scanf("%d",&n);
    for(int i=0;i<n;i++){
       scanf("%d",&t);
       members[t-1] ++;
    }
    //sort
    for(int i=0;i<2;i++){
      for(int j=2;j>i;j--){
          if(members[orders[j]] <
         members[j-1]){
          t = orders[j];
          orders[j] = orders[j-1];
          orders[j-1] = t;
        }
      }
    }
    for(int i=0;i<3;i++){
      cout<<
       orders[i]<<
       names[orders[i]-1] <<
       members[orders[i]-1];
    }
    return 0;
}