結果
| 問題 |
No.994 ばらばらコイン
|
| コンテスト | |
| ユーザー |
g4np0n_kyopro
|
| 提出日時 | 2020-02-21 21:55:24 |
| 言語 | C#(csc) (csc 3.9.0) |
| 結果 |
AC
|
| 実行時間 | 256 ms / 2,000 ms |
| コード長 | 3,814 bytes |
| コンパイル時間 | 1,500 ms |
| コンパイル使用メモリ | 117,808 KB |
| 実行使用メモリ | 34,560 KB |
| 最終ジャッジ日時 | 2024-10-08 21:39:35 |
| 合計ジャッジ時間 | 5,483 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 23 |
コンパイルメッセージ
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.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace AtCoder
{
static class Program
{
static void Main()
{
//Console.SetOut(new StreamWriter(Console.OpenStandardOutput()) { AutoFlush = false });
//
int N;int K;
Multi(out N, out K);
List<List<int>> Edge = new List<List<int>>();
for(int i = 0; i < N; i++)
{
Edge.Add(new List<int>());
}
for(int i = 0; i < N - 1; i++)
{
var cin = GetIntArray().Select(s => s - 1).ToArray();
Edge[cin[0]].Add(cin[1]);
Edge[cin[1]].Add(cin[0]);
}
int[] dist = Enumerable.Repeat(-1, N).ToArray();
var que = new Queue<int>();
que.Enqueue(0);
dist[0] = 0;
while (que.Count > 0)
{
var n = que.Dequeue();
foreach(var e in Edge[n])
{
if (dist[e] == -1)
{
dist[e] = dist[n] + 1;
que.Enqueue(e);
}
}
}
int ans;
if (dist.Count(d => d != -1) >= K)
{
ans = K - 1;
}
else
{
ans = -1;
}
Console.WriteLine(ans);
//
//Console.Out.Flush();
Console.ReadKey();
}
static public string GetStr() { return Console.ReadLine().Trim(); }
static public int GetInt() { return int.Parse(Console.ReadLine()); }
static public long GetLong() { return long.Parse(Console.ReadLine()); }
static public string[] GetStrArray() { return Console.ReadLine().Split(' '); }
static public int[] GetIntArray() { return Console.ReadLine().Split(' ').Select(int.Parse).ToArray(); }
static public long[] GetLongArray() { return Console.ReadLine().Split(' ').Select(long.Parse).ToArray(); }
static public char[] GetCharArray() { return Console.ReadLine().Split(' ').Select(char.Parse).ToArray(); }
static public List<double> GetDoubleList() { return Console.ReadLine().Split(' ').Select(double.Parse).ToList(); }
static public void WriteObjects<T>(IEnumerable<T> values) { foreach (var o in values) { Console.Write(o + " "); } }
static string yesno(this bool b) { return b ? "yes" : "no"; }
static string YesNo(this bool b) { return b ? "Yes" : "No"; }
static string YESNO(this bool b) { return b ? "YES" : "NO"; }
static bool eq<T, U>() => typeof(T).Equals(typeof(U));
static T ct<T, U>(U a) => (T)Convert.ChangeType(a, typeof(T));
static T cv<T>(string s) => eq<T, int>() ? ct<T, int>(int.Parse(s))
: eq<T, long>() ? ct<T, long>(long.Parse(s))
: eq<T, double>() ? ct<T, double>(double.Parse(s))
: eq<T, char>() ? ct<T, char>(s[0])
: ct<T, string>(s);
static void Multi<T>(out T a) => a = cv<T>(GetStr());
static void Multi<T, U>(out T a, out U b)
{
var ar = GetStrArray(); a = cv<T>(ar[0]); b = cv<U>(ar[1]);
}
static void Multi<T, U, V>(out T a, out U b, out V c)
{
var ar = GetStrArray(); a = cv<T>(ar[0]); b = cv<U>(ar[1]); c = cv<V>(ar[2]);
}
static void Multi<T, U, V>(out T a, out U b, out V c, out V d)
{
var ar = GetStrArray(); a = cv<T>(ar[0]); b = cv<U>(ar[1]); c = cv<V>(ar[2]); d = cv<V>(ar[3]);
}
}
}
g4np0n_kyopro