結果
| 問題 |
No.279 木の数え上げ
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2015-10-05 01:33:49 |
| 言語 | C#(csc) (csc 3.9.0) |
| 結果 |
AC
|
| 実行時間 | 51 ms / 2,000 ms |
| コード長 | 1,798 bytes |
| コンパイル時間 | 928 ms |
| コンパイル使用メモリ | 116,820 KB |
| 実行使用メモリ | 31,356 KB |
| 最終ジャッジ日時 | 2024-10-14 15:15:18 |
| 合計ジャッジ時間 | 2,529 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 21 |
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 3.9.0-6.21124.20 (db94f4cc) Copyright (C) Microsoft Corporation. All rights reserved.
ソースコード
using System;
using System.Linq;
using System.Text;
using System.Collections.Generic;
class Program
{
static void Main(string[] args)
{
char[] s = LIB.IO.R<string>().ToCharArray();
int tc = s.Where(c => c == 't').Count();
int rc = s.Where(c => c == 'r').Count();
int ec = s.Where(c => c == 'e').Count() / 2;
int ans = Math.Min(tc, rc);
ans = Math.Min(ans, ec);
LIB.IO.W(ans);
LIB.IO.WFLUSH();
}
}
namespace LIB
{
public class IO
{
private const int WMAX = 1000;
private static StringBuilder S = new StringBuilder();
public static T R<T>() { return UTILITY.PARSE<T>(R()); }
public static T[] R<T>(char s = ' ') { return R().Split(s).Select(UTILITY.PARSE<T>).ToArray(); }
public static T[] R<T>(int l) { T[] r = new T[l]; for (int i = 0; i < l; i++) { r[i] = R<T>(); } return r; }
public static T[][] R<T>(int l, char s = ' ') { T[][] r = new T[l][]; for (int i = 0; i < l; i++) { r[i] = R<T>(s); } return r; }
private static string R() { return Console.ReadLine(); }
public static void W(object v, bool lf = true) { S.Append(UTILITY.PARSE<string>(v)); if (lf == true) { S.Append('\n'); } if (S.Length >= WMAX) { WFLUSH(); } }
public static void WFLUSH() { Console.Write(S.ToString()); S.Clear(); }
}
public class UTILITY
{
public static T PARSE<T>(object value) { return (T)(Convert.ChangeType(value, typeof(T))); }
}
public class MEMO<Key, Result>
{
private Dictionary<Key, Result> R;
public MEMO() { R = new Dictionary<Key, Result>(); }
public Result EXEC(Key k, Func<Key, Result> f) { Result r; if (R.ContainsKey(k)) { r = R[k]; } else { r = f(k); R.Add(k, r); } return r; }
}
}