結果
| 問題 |
No.26 シャッフルゲーム
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2017-10-28 05:17:42 |
| 言語 | C#(csc) (csc 3.9.0) |
| 結果 |
AC
|
| 実行時間 | 28 ms / 5,000 ms |
| コード長 | 1,706 bytes |
| コンパイル時間 | 3,560 ms |
| コンパイル使用メモリ | 113,260 KB |
| 実行使用メモリ | 27,388 KB |
| 最終ジャッジ日時 | 2024-11-22 00:58:10 |
| 合計ジャッジ時間 | 3,455 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 10 |
コンパイルメッセージ
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;
namespace yukicodeX {
public class Program {
public static int Solver(System.IO.TextReader reader) {
const int QTY_CUP= 3;
var n = 1 << ( QTY_CUP - int.Parse( reader.ReadLine() ) );
var m = int.Parse( reader.ReadLine() );
for (var i = 0; i != m; ++i) {
var buf = MyLib.GetIntList( reader.ReadLine() );
var p = 1 << ( QTY_CUP - buf[ 0 ] );
var q = 1 << ( QTY_CUP - buf[ 1 ] );
var nn = n & ( p | q );
if (nn > 0) n = n ^ ( p | q );
}
return (int)( QTY_CUP - Math.Log( n ) / Math.Log( 2 ) );
}
private static void Main() {
Console.WriteLine( Solver( Console.In ) );
}
}
public class MyLib {
public static string Ordinalization(int num) {
string surfix = "stndrdth";
return string.Format( "{0}{1}", num,
( 0 < num % 10 && num % 10 <= 4 ) && ( ( num % 100 ) / 10 != 1 ) ?
surfix.Substring( ( num % 10 - 1 ) * 2, 2 ) : surfix.Substring( 6 ) );
}
public static List<int> GetIntList(string input) {
return input.Split().ToList<string>().ConvertAll<int>( int.Parse );
}
public static List<int> GetIntList(string input, char delimitor) {
return input.Split( delimitor ).ToList<string>().ConvertAll<int>( int.Parse );
}
public static List<int> GetIntList(string input, char[] delimitors) {
return input.Split( delimitors ).ToList<string>().ConvertAll<int>( int.Parse );
}
}
}