結果

問題 No.449 ゆきこーだーの雨と雪 (4)
ユーザー くれちー
提出日時 2016-11-19 16:48:11
言語 C#(csc)
(csc 3.9.0)
結果
TLE  
実行時間 -
コード長 3,244 bytes
コンパイル時間 2,299 ms
コンパイル使用メモリ 115,272 KB
実行使用メモリ 26,312 KB
最終ジャッジ日時 2024-09-22 10:24:47
合計ジャッジ時間 9,911 ms
ジャッジサーバーID
(参考情報)
judge5 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 9 TLE * 1 -- * 33
権限があれば一括ダウンロードができます
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 3.9.0-6.21124.20 (db94f4cc)
Copyright (C) Microsoft Corporation. All rights reserved.

ソースコード

diff #

using System;
using System.Collections.Generic;

class Problem
{
    public char Name { get; set; }
    public int Level { get; set; }
    public int Solve { get; set; } = 0;

    public Problem(int level)
    {
        Level = level;
    }

    public static int GetId(char name)
    {
        return name - 'A';
    }
}

class Submit
{
    public string Name { get; set; }
    public char ProblemName { get; set; }

    public Submit(string name, char problemName)
    {
        Name = name;
        ProblemName = problemName;
    }
}

class Participant : IEquatable<Participant>, IComparable<Participant>
{
    public string Name { get; set; }
    public List<int> Score { get; set; }
    public int ScoreSum { get; set; } = 0;
    public int LastSubmit { get; set; }

    public Participant(string name)
    {
        Name = name;
    }
    public Participant(string name, int problemNum, int lastSubmit)
    {
        Name = name;
        Score = new List<int>();
        for (int i = 0; i < problemNum; i++) Score.Add(0);
        LastSubmit = lastSubmit;
    }

    bool IEquatable<Participant>.Equals(Participant p)
    {
        if (p == null) return false;
        else return (Name == p.Name);
    }

    public int CompareTo(Participant p)
    {
        if (ScoreSum.CompareTo(p.ScoreSum) == 0)
            return LastSubmit.CompareTo(p.LastSubmit);
        else
            return p.ScoreSum.CompareTo(ScoreSum);
    }

    public void Solve(int no, int level, int rank)
    {
        Score[no] = 50 * level + (500 * level / (8 + 2 * rank));
        ScoreSum += Score[no];
    }
}

class Program
{
    static void Main()
    {
        int N = int.Parse(Console.ReadLine());
        var problemList = new List<Problem>(N);

        string[] strtmp = Console.ReadLine().Split(' ');
        for (int i = 0; i < N; i++)
            problemList.Add(new Problem(int.Parse(strtmp[i])));

        int T = int.Parse(Console.ReadLine());
        var submitList = new List<Submit>(T);
        var participantList = new List<Participant>();

        int cntSubmit = 0;
        for (int i = 0; i < T; i++)
        {
            strtmp = Console.ReadLine().Split(' ');

            if (strtmp[1] == "?")
            {
                participantList.Sort();
                Console.WriteLine(participantList.IndexOf(new Participant(strtmp[0])) + 1);
            }
            else
            {
                submitList.Add(new Submit(strtmp[0], char.Parse(strtmp[1])));

                if (!participantList.Contains(new Participant(submitList[cntSubmit].Name)))
                    participantList.Add(new Participant(submitList[cntSubmit].Name, N, cntSubmit));

                int tmpProblemNo =
                    Problem.GetId(submitList[cntSubmit].ProblemName);
                int tmpParticipantNo =
                    participantList.IndexOf(new Participant(submitList[cntSubmit].Name));

                problemList[tmpProblemNo].Solve++;
                participantList[tmpParticipantNo].Solve(
                    tmpProblemNo, problemList[tmpProblemNo].Level, problemList[tmpProblemNo].Solve);
                participantList[tmpParticipantNo].LastSubmit = cntSubmit;

                cntSubmit++;
            }
        }
    }
}
0