网页资讯视频图片知道文库贴吧地图采购
进入贴吧全吧搜索

 
 
 
日一二三四五六
       
       
       
       
       
       

签到排名:今日本吧第个签到,

本吧因你更精彩,明天继续来努力!

本吧签到人数:0

一键签到
成为超级会员,使用一键签到
一键签到
本月漏签0次!
0
成为超级会员,赠送8张补签卡
如何使用?
点击日历上漏签日期,即可进行补签。
连续签到:天  累计签到:天
0
超级会员单次开通12个月以上,赠送连续签到卡3张
使用连续签到卡
08月02日漏签0天
c++吧 关注:627,011贴子:2,112,801
  • 看贴

  • 图片

  • 吧主推荐

  • 游戏

  • 1 2 下一页 尾页
  • 38回复贴,共2页
  • ,跳到 页  
<<返回c++吧
>0< 加载中...

求指点-DevC++编程解题:奖学金

  • 只看楼主
  • 收藏

  • 回复
  • 樱雪雨馨
  • ?:
    4
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
1L百度


  • promisesme1
  • ||
    5
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
我要奖学金


2025-08-02 10:41:03
广告
不感兴趣
开通SVIP免广告
  • 樱雪雨馨
  • ?:
    4
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
以下是自编的程序代码,请高手们看看哪里出错了:
#include<iostream>
#include<fstream>
#include<cstdio>
#define MAX 300
using namespace std;
int main()
{
int c[MAX],s[MAX],o[MAX];
int n,x,y;
int t,i,j,max;
scanf("%d",&n);
for(i=0;i<n;i++){
scanf("%d%d%d",&c[i],&x,&y);
s[i]=c[i]+x+y;
o[i]=i+1;
}
for(i=0;i<n-1;i++){
max=i;
for(j=i+1;j<n;j++){
if(s[j]>s[i]||
s[j]==s[i]&&c[j]>c[i]||
s[j]==s[i]&&c[j]==c[i]&&o[j]<o[i])
max=j;
}
if(max!=i){
t=s[i];
s[i]=s[max];
s[max]=t;
t=c[i];
c[i]=c[max];
c[max]=t;
t=o[i];
o[i]=o[max];
o[max]=t;
}
}
for(i=0;i<5;i++)
printf("%d %d\n",o[i],s[i]);
return 0;
}



  • shixuedongzhen
  • ^
    8
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
目测,定义结构体,重载<运算符,使用vecor,使用sort排序解决....


  • farteryhr
  • throw
    3
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
样例数据里面出现了两个连续的正确的数值


  • yjf_victor
  • <
    11
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
这是OI试题还是ACM试题啊?


  • NarcissaBlack
  • <
    11
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
lz也是OIer握爪


  • 樱雪雨馨
  • ?:
    4
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
【样例1】
  6
  90 67 80
  87 66 91
  78 89 91
  88 99 77
  67 ****
  78 89 98
【样例2】
  8
  80 89 89
  88 98 78
  90 67 80
  87 66 91
  78 89 91
  88 99 77
  67 ****
  78 89 98



2025-08-02 10:35:03
广告
不感兴趣
开通SVIP免广告
  • 樱雪雨馨
  • ?:
    4
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
**:****


  • yjf_victor
  • <
    11
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
星号是什么


  • yjf_victor
  • <
    11
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
C函数库qosrt
C++ STL库std::sort
搞定


  • 樱雪雨馨
  • ?:
    4
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
额 这题是从书上看到的 没有答案。。


  • 樱雪雨馨
  • ?:
    4
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
星号是 八九 **


  • yjf_victor
  • <
    11
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
#include <stdio.h>
#include <stdlib.h>
typedef struct { int number, chinese, math, english, total; } STUDENT;
#define MAX_STUDENT 100
int compare ( const void * a , const void * b )
{
    if ( ((const STUDENT *)a)->total != ((const STUDENT *)b)->total )
        return ((const STUDENT *)b)->total - ((const STUDENT *)a)->total;
    else if ( ((const STUDENT *)a)->chinese != ((const STUDENT *)b)->chinese )
        return ((const STUDENT *)b)->chinese - ((const STUDENT *)a)->chinese;
    else
        return ((const STUDENT *)a)->number - ((const STUDENT *)b)->number;
}
int main (void)
{
    int n;
    int i;
    STUDENT student[MAX_STUDENT];
    scanf( "%d", &n );
    for ( i = 0 ; i < n ; i ++ )
    {
        student[i].number = i + 1;
        scanf("%d%d%d", &(student[i].chinese), &(student[i].math), &(student[i].english) );
        student[i].total = student[i].chinese + student[i].math + student[i].english;
    }
    qsort( student, n, sizeof(student[0]), compare );
    for ( i = 0 ; i < 5 ; i ++ )
        printf( "%d %d\n", student[i].number, student[i].total );
    return 0;
}



2025-08-02 10:29:03
广告
不感兴趣
开通SVIP免广告
  • yjf_victor
  • <
    11
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
#include <iostream>
#include <algorithm>
using namespace std;
typedef struct { int number, chinese, math, english, total; } STUDENT;
#define MAX_STUDENT 10000
bool compare ( const STUDENT a , const STUDENT b )
{
    if ( a.total != b.total )
        return a.total > b.total;
    else if ( a.chinese != b.chinese )
        return a.chinese > b.chinese;
    else
        return a.number < b.number;
}
int main (void)
{
    int n;
    int i;
    STUDENT student[MAX_STUDENT];
    cin >> n;
    for ( i = 0 ; i < n ; i ++ )
    {
        student[i].number = i + 1;
        cin >> student[i].chinese >> student[i].math >> student[i].english;
        student[i].total = student[i].chinese + student[i].math + student[i].english;
    }
    sort( student, student + n, compare );
    for ( i = 0 ; i < 5 ; i ++ )
        cout << student[i].number << " " << student[i].total << endl;
    return 0;
}



登录百度账号

扫二维码下载贴吧客户端

下载贴吧APP
看高清直播、视频!
  • 贴吧页面意见反馈
  • 违规贴吧举报反馈通道
  • 贴吧违规信息处理公示
  • 1 2 下一页 尾页
  • 38回复贴,共2页
  • ,跳到 页  
<<返回c++吧
分享到:
©2025 Baidu贴吧协议|隐私政策|吧主制度|意见反馈|网络谣言警示