結果
| 問題 |
No.647 明太子
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2018-05-21 14:10:20 |
| 言語 | C#(csc) (csc 3.9.0) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 2,072 bytes |
| コンパイル時間 | 934 ms |
| コンパイル使用メモリ | 113,372 KB |
| 実行使用メモリ | 54,528 KB |
| 最終ジャッジ日時 | 2024-06-28 14:56:55 |
| 合計ジャッジ時間 | 18,684 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 13 TLE * 2 -- * 5 |
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 3.9.0-6.21124.20 (db94f4cc) Copyright (C) Microsoft Corporation. All rights reserved.
ソースコード
using System;
using System.Collections.Generic;
using System.Linq;
public class Program
{
static void Main()
{
List<Member> Members = new List<Member>();
List<int> Kiseki = new List<int>();
Kiseki.Add(0);
int MaxNum = 0;
int KaiCount = 0;
for(var i = int.Parse(Console.ReadLine()); i>0 ;i--){
Members.Add( Member.MakeMember( Splitter( Console.ReadLine() ).Select( a => int.Parse(a) ).ToList() ) );
}
var MembersList = Members.OrderByDescending(a => a.Yosan).ThenBy(a => a.Karasa).GroupBy(b => b.Yosan);
int MentaiMax = int.Parse(Console.ReadLine());
List<int> Tmp = new List<int>();
for(var j = 1; j <= MentaiMax ;j++){
KaiCount = 0;
Tmp = Splitter( Console.ReadLine() ).Select( a => int.Parse(a) ).ToList();
foreach(var k in MembersList){
if(k.Key < Tmp[0]){
break;
}
foreach(var l in k){
if(l.Karasa > Tmp[1]){
break;
}
KaiCount ++;
}
}
if(KaiCount > MaxNum){
Kiseki.Clear();
MaxNum = KaiCount;
Kiseki.Add(j);
}else if(KaiCount == MaxNum && MaxNum != 0){
Kiseki.Add(j);
}
}
foreach(var m in Kiseki){
Console.WriteLine(m);
}
}
static List<string> Splitter(string Input, char Delimiter = ' '){
return new List<string>(Input.Split(Delimiter));
}
}
public class Member
{
public int Yosan;
public int Karasa;
public Member(int InYosan, int InKarasa){
Yosan = InYosan;
Karasa = InKarasa;
}
public bool Kauka(List<int> list){
return (list[0] <= Yosan) && (list[1] >= Karasa);
}
public static Member MakeMember(List<int> list){
return new Member(list[0],list[1]);
}
}