zoukankan      html  css  js  c++  java
  • PAT 1012 The Best Rank

    暴力、打表(记忆已经查询过的学号对应的排名,防止反复查询同一学号)

    因为题目中已经规定学号是6位数,所以用int表示方便打表。

      1 #include <iostream> 
      2 #include <stdio.h>
      3 #include <string>
      4 #include <algorithm>
      5 
      6 using namespace std;
      7 
      8 int n, m;
      9 struct Student
     10 {
     11     int id;
     12     int C;
     13     int M;
     14     int E;
     15     int A;
     16 }stu[2010];
     17 
     18 // 内置函数有rank,所以这里不起名为rank 
     19 // 打表 
     20 int rank1[1000000];        //排名最高时候的名次 
     21 char rank2[1000000];    //排名最高对应的科目 
     22 
     23 
     24 int getMin(int a, int b, int c, int d)
     25 {
     26     int Min = a;
     27     Min = min(Min, b);
     28     Min = min(Min, c);
     29     Min = min(Min, d);
     30     
     31     return Min;
     32 }
     33 
     34 
     35 int main()
     36 {
     37     cin >> n >> m;
     38     for(int i = 1; i <= n; ++i)
     39     {
     40         scanf("%d%d%d%d", &stu[i].id, &stu[i].C, &stu[i].M, &stu[i].E);
     41         stu[i].A = (stu[i].C + stu[i].M + stu[i].E) / 3;
     42     }
     43     
     44     for(int k = 1; k <= m; ++k)
     45     {
     46         int sid;    //待查找排名的学生的学号
     47         scanf("%d", &sid);
     48         if(rank1[sid] != 0)
     49         {
     50             if(k != m)
     51                 cout << rank1[sid] << ' ' << rank2[sid] << endl;
     52             else
     53                 cout << rank1[sid] << ' ' << rank2[sid];
     54             continue; 
     55         }
     56         
     57         int curScoreA = -1;
     58         int curScoreC = -1;
     59         int curScoreM = -1;
     60         int curScoreE = -1;
     61         
     62         int curRankA = 1; 
     63         int curRankC = 1; 
     64         int curRankM = 1; 
     65         int curRankE = 1;
     66         
     67         int curRank = -1; 
     68         char curRankSubject = 'A';
     69         
     70         for(int i = 1; i <= n; ++i)
     71         {
     72             if(stu[i].id == sid)
     73             {
     74                 curScoreA = stu[i].A;
     75                 curScoreC = stu[i].C;
     76                 curScoreM = stu[i].M;
     77                 curScoreE = stu[i].E;
     78             }
     79         }
     80         
     81         // 学号不存在 
     82         if(curScoreA == -1)
     83         {
     84             if(k != m)
     85                 cout << "N/A" << endl;
     86             else
     87                 cout << "N/A";
     88             
     89             continue;
     90         }
     91         
     92         for(int i = 1; i <= n; ++i)
     93         {
     94             if(stu[i].id != sid)
     95             {
     96                 // 注意这里不能写等号,分数一样都按排名最前的来算 
     97                 if(stu[i].A > curScoreA)
     98                     curRankA++;
     99                 if(stu[i].C > curScoreC)
    100                     curRankC++;
    101                 if(stu[i].M > curScoreM)
    102                     curRankM++;
    103                 if(stu[i].E > curScoreE)
    104                     curRankE++;    
    105             }
    106         }
    107         
    108         curRank = getMin(curRankA, curRankC, curRankM, curRankE) ;
    109         if(curRank == curRankA)
    110             curRankSubject = 'A';
    111         else if(curRank == curRankC)
    112             curRankSubject = 'C';
    113         else if(curRank == curRankM)
    114             curRankSubject = 'M';
    115         else if(curRank == curRankE)
    116             curRankSubject = 'E';
    117         
    118         rank1[sid] = curRank;
    119         rank2[sid] = curRankSubject;
    120         
    121         
    122         if(k != m)
    123             cout << rank1[sid] << ' ' << rank2[sid] << endl;
    124         else
    125             cout << rank1[sid] << ' ' << rank2[sid];
    126         
    127         
    128     }
    129 
    130 
    131     return 0;
    132 }
  • 相关阅读:
    C# 调用C++ dll 返回char*调用方式(StringBuilder乱码)
    Linux/Centos下安装部署phantomjs
    SQLEXPR_x64_CHS、SQLEXPRADV_x64_CHS、SQLEXPRWT_x64_CHS、SqlLocalDB、SQLManagementStudio_x64_CHS各版本说明
    linux安装phantomjs,-bash: /usr/local/bin/phantomjs: is a directory解决方案
    [转]EAS BOS MsgBox使用大全
    SQL 2005用Windows身份验证登陆18456错误
    [原]EAS动态扩展平台(DEP)服务端调用oracle存储过程
    Uuid, BOSObjectType, BosUUid 区别
    [转]oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务。
    [转]如何拷贝一个 SQL Server 的表
  • 原文地址:https://www.cnblogs.com/FengZeng666/p/12601883.html
Copyright © 2011-2022 走看看