結果
| 問題 | 
                            No.91 赤、緑、青の石
                             | 
                    
| コンテスト | |
| ユーザー | 
                             14番
                         | 
                    
| 提出日時 | 2016-04-10 12:39:38 | 
| 言語 | C#(csc)  (csc 3.9.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 29 ms / 5,000 ms | 
| コード長 | 3,025 bytes | 
| コンパイル時間 | 948 ms | 
| コンパイル使用メモリ | 113,072 KB | 
| 実行使用メモリ | 26,516 KB | 
| 最終ジャッジ日時 | 2024-06-24 06:58:05 | 
| 合計ジャッジ時間 | 3,025 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge5 / judge1 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 4 | 
| other | AC * 28 | 
コンパイルメッセージ
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.Text;
class Program
{
    public void Proc()
    {
        Reader.IsDebug = false;
        List<int> numList = new List<int>();
        numList.AddRange(Reader.GetInt());
        numList.Sort();
        // 要分配
        while (numList[2] - numList[0] > 2)
        {
            if (numList[2] - numList[1] > 4 && numList[1] - numList[0] <= 1)
            {
                // 一番大きいものから小さいもの2つへ
                int must = (numList[2] - numList[1]) / 5;
                numList[2] -= must * 4;
                numList[1] += must;
                numList[0] += must;
            }
            else if (numList[1] - numList[0] > 3 && numList[2] - numList[1] <= 1)
            {
                // 大きいもの2つから一番小さいものへ
                int must = (numList[1] - numList[0]) / 4;
                if (must == 0)
                {
                    break;
                }
                numList[2] -= must * 2;
                numList[1] -= must * 2;
                numList[0] += must * 2;
            }
            else
            {
                // 一番大きいものから小さいものへ
                if (numList[2] - numList[1] <= 1)
                {
                    numList[2] -= 2;
                    numList[0] += 1;
                }
                else
                {
                    int must = Math.Min((numList[2] - numList[1]) / 2, numList[1] - numList[0]);
                    if (must == 0)
                    {
                        break;
                    }
                    numList[2] -= must * 2;
                    numList[0] += must;
                }
            }
            numList.Sort();
        }
        numList.Sort();
        Console.WriteLine(numList[0]);
    
    }
    public class Reader
    {
        public static bool IsDebug = true;
        private static String PlainInput = @"
7777777 3 9999999
 
";
        private static System.IO.StringReader Sr = null;
        public static string ReadLine()
        {
            if (IsDebug)
            {
                if (Sr == null)
                {
                    Sr = new System.IO.StringReader(PlainInput.Trim());
                }
                return Sr.ReadLine();
            }
            else
            {
                return Console.ReadLine();
            }
        }
        public static int[] GetInt(char delimiter = ' ', bool trim = false)
        {
            string inptStr = ReadLine();
            if (trim)
            {
                inptStr = inptStr.Trim();
            }
            string[] inpt = inptStr.Split(delimiter);
            int[] ret = new int[inpt.Length];
            for (int i = 0; i < inpt.Length; i++)
            {
                ret[i] = int.Parse(inpt[i]);
            }
            return ret;
        }
    }
    static void Main()
    {
        Program prg = new Program();
        prg.Proc();
    }
}
            
            
            
        
            
14番