hdu 2093 考试排名(结构体排序)

对“到文件结束”理解

代码:

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;

struct node
{
    char name[20];
    int num;
    int t;
    void init()
    {
        t=0;
        num=0;
    }
};

int cmp(const node a,const node b)
{
    if(a.num==b.num&&a.t==b.t)
    {
        return strcmp(a.name,b.name)<0;
    }
    else if(a.num==b.num)
    {
        return a.t<b.t;
    }
    else
    {
        return a.num>b.num;
    }
}

int f(int n)
{
    int ans=1;
    while(n--)
    {
        ans=ans*10;
    }
    return ans;
}

node stu[10000];
char str[20];

int main()
{
    int n,m;
    while(scanf("%d%d",&n,&m)==2)
    {
        int i=0;
        while(~scanf("%s",stu[i].name))
        {
            stu[i].init();
            for(int j=0;j<n;j++)
            {
                scanf("%s",str);
                int len=strlen(str);
                if(str[0]=='-'||str[0]=='0')
                    continue;
                int len1=0;
                for(int k=0;k<len;k++)
                {
                    if(str[k]=='(')
                    {
                        len1=k;
                        break;
                    }
                }
                if(len1==0)
                {
                    for(int k=0;k<len;k++)
                    {
                        stu[i].t=stu[i].t+(str[k]-'0')*f(len-k-1);
                    }
                    stu[i].num++;
                }
                else
                {
                    for(int k=0;k<len1;k++)
                    {
                        stu[i].t=stu[i].t+(str[k]-'0')*f(len1-k-1);
                    }
                    int len2=len-len1-2;
                    int ttt=0;
                    for(int k=len1+1;k<len-1;k++)
                    {
                        ttt=ttt+(str[k]-'0')*f(len2-1);
                        len2--;
                    }
                    stu[i].t+=(ttt*m);
                    stu[i].num++;
                }
            }
            i++;
        }
        sort(stu,stu+i,cmp);
        for(int j=0;j<i;j++)
        {
            printf("%-10s %2d %4d\n",stu[j].name,stu[j].num,stu[j].t);
        }
    }
    return 0;
}
时间: 2024-10-23 09:15:31

hdu 2093 考试排名(结构体排序)的相关文章

HDU 2093 考试排名

HDU 2093 考试排名 /* HDU 2093 考试排名 */ #include <cstdio> #include <string> #include <queue> #include <iostream> using namespace std; struct Node{ string name; int n; int useTime; bool operator<(const Node& rhs) const { //先按从n的值从大

题解报告:hdu 2093 考试排名

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2093 Problem Description C++编程考试使用的实时提交系统,具有即时获得成绩排名的特点.它的功能是怎么实现的呢? 我们做好了题目的解答,提交之后,要么"AC",要么错误,不管怎样错法,总是给你记上一笔,表明你曾经有过一次错误提交,因而当你一旦提交该题"AC"后,就要与你算一算帐了,总共该题错误提交了几回.虽然你在题数上,大步地跃上了一个台阶,但是在耗

HDU 2093考试排名

考试排名 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 9543    Accepted Submission(s): 3327 Problem Description C++编程考试使用的实时提交系统,具有即时获得成绩排名的特点.它的功能是怎么实现的呢? 我们做好了题目的解答,提交之后,要么"AC",要么错误,不管怎样错法

JustOj 2039: 成绩排名 (结构体排序)

题目描述 每次期末考试成绩出来之前的一段时间大豪哥心里都是痛苦的,总感觉自己会在班上排名特别差.所以当成绩出来以后大豪哥想快点知道班上的总排名,以便知道自己的排名.(PS:大豪哥班上有个学霸名叫日天,又名泰迪,不要问我为什么,因为泰迪的行为决定的) 输入 多组测试数据,至文件结尾.先输入每个班上有n个同学,这个学期有m门课程(1<=n,m<=100)接下来有n行,每行的输入格式为学号id,姓名name,课程成绩k1,课程成绩k2... ,课程成绩km.(学号在int型范围以内,0<=ki

HDU 1084 [What Is Your Grade?] 结构体排序

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1084 题目大意:共5道题,N个学生.做出5道满分,0道50分.做出1-4道的同学,若在前50%(向下取整),则获得95.85.75.65,若在后50%则获得90.80.70.60. 关键思想:结构体排序 //结构体排序,考虑边界 #include <iostream> #include <algorithm> #include <cmath> #include <me

HDU 1862 EXCEL排序(结构体排序)

EXCEL排序 Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 16387    Accepted Submission(s): 6137 Problem Description Excel可以对一组纪录按任意指定列排序.现请你编写程序实现类似功能. Input 测试输入包含若干测试用例.每个测试用例的第1行包含两个整数 N (<=1

HDU 2409 Team Arrangement (结构体排序)

题目链接:HDU 2409 Team Arrangement 题意:给出22个人(编号,名字,踢的位置,在队里的时间),让我们选DD-MM-SS的阵型+一个守门员.在选出队长(时间在最久的就是队长,时间相同编号大为队长),选人的顺序是从编号小的开始. 结构体排序就好了,注意出输出是按队长,D,M,S的顺序,选队长记录队长的编号(而不是下标,我的代码之后还要排序). AC代码: #include<stdio.h> #include<string.h> #include<algo

hdu 5702 Solving Order(结构体排序 水题)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5702 Solving Order Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 184    Accepted Submission(s): 135 Problem Description Welcome to HDU to take p

hdu 1070(结构体排序)

Milk Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 13639    Accepted Submission(s): 3328 Problem Description Ignatius drinks milk everyday, now he is in the supermarket and he wants to choose