結果

問題 No.850 企業コンテスト2位
コンテスト
ユーザー kakel-san
提出日時 2026-04-15 22:28:18
言語 C#
(.NET 10.0.201)
コンパイル:
dotnet_c
実行:
/usr/bin/dotnet_wrap
結果
AC  
実行時間 101 ms / 2,000 ms
コード長 1,860 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 6,754 ms
コンパイル使用メモリ 173,304 KB
実行使用メモリ 51,872 KB
平均クエリ数 200.11
最終ジャッジ日時 2026-04-15 22:28:44
合計ジャッジ時間 10,570 ms
ジャッジサーバーID
(参考情報)
judge3_0 / judge1_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 27
権限があれば一括ダウンロードができます
コンパイルメッセージ
  復元対象のプロジェクトを決定しています...
  /home/judge/data/code/main.csproj を復元しました (89 ミリ秒)。
  main -> /home/judge/data/code/bin/Release/net10.0/main.dll
  main -> /home/judge/data/code/bin/Release/net10.0/publish/

ソースコード

diff #
raw source code

using System;
using static System.Console;
using System.Linq;
using System.Collections.Generic;
using System.Runtime.Intrinsics.Arm;

class Program
{
    static int NN => int.Parse(ReadLine());
    static int[] NList => ReadLine().Split().Select(int.Parse).ToArray();
    static int[][] NArr(long n) => Enumerable.Repeat(0, (int)n).Select(_ => NList).ToArray();
    public static void Main()
    {
        Solve();
    }
    static void Solve()
    {
        var n = NN;
        if (n == 2)
        {
            var q = Que(1, 2);
            Ans(3 - q);
            return;
        }
        var lose = new int[n + 1];
        var list = new List<int>();
        for (var i = 1; i <= n; ++i) list.Add(i);
        while (list.Count > 1)
        {
            var nlist = new List<int>();
            for (var i = 0; i + 1 < list.Count; i += 2)
            {
                var win = Que(list[i], list[i + 1]);
                if (win == list[i]) lose[list[i + 1]] = list[i];
                else lose[list[i]] = list[i + 1];
                nlist.Add(win);
            }
            if (list.Count % 2 == 1) nlist.Add(list[^1]);
            list = nlist;
        }
        var llist = new List<int>();
        for (var i = 1; i <= n; ++i) if (lose[i] == list[0]) llist.Add(i);
        while (llist.Count > 1)
        {
            var nlist = new List<int>();
            for (var i = 0; i + 1 < llist.Count; i += 2)
            {
                nlist.Add(Que(llist[i], llist[i + 1]));
            }
            if (llist.Count % 2 == 1) nlist.Add(llist[^1]);
            llist = nlist;
        }
        Ans(llist[0]);
    }
    static int Que(int x, int y)
    {
        WriteLine($"? {x} {y}");
        return NN;
    }
    static void Ans(int x)
    {
        WriteLine($"! {x}");
    }
}
0