ケヴィンのなんかいろいろ

ハースストーンとかその他色々なことについて話すブログです

MENU

Atcoder進捗

今更Atcoder始めたので、みんな大好きAtCoder Beginners Selection - AtCoderを解いてました。ただちょっと詰まっちゃったので、考えの整理ついでに記録します。

フォルダ名に空白が入ってるからなのか、githubの埋め込みが上手く使えないのがほんと不覚すぎた・・・。

ABC086A - Product

ABC086A - Product

using System;

namespace ABC086A
{
    class Program
    {
        static void Main(string[] args)
        {
            string[] input = Console.ReadLine().Split(' ');
            var num = int.Parse(input[0]);
            num *= int.Parse(input[1]);
            if(num % 2 == 0)
            {
                Console.WriteLine("Even");
            }
            else
            {
                Console.WriteLine("Odd");
            }
        }
    }
}

入力が空白で区切られてるから、Split(' ')で分割して、int.Parseで変換してます。んで掛けて2で割って偶奇見て終わりっ!

ABC081A - Placing Marbles

ABC081A - Placing Marbles

using System;
using System.Linq;

namespace ABC081A
{
    class Program
    {
        static void Main(string[] args)
        {
            string input = Console.ReadLine();
            char[] array = input.ToArray();
            int num = 0;
            for (int i = 0; i < 3; i++)
            {
                num += int.Parse(array[i].ToString());
            }
            Console.WriteLine(num);
        }
    }
}

一桁ずつ見たいからToArrayで分解して全部足す!終わりっ!

ABC081B - Shift only

ABC081B - Shift only

using System;
using System.Collections.Generic;

namespace ABC081B
{
    class Program
    {
        static void Main(string[] args)
        {
            int number = int.Parse(Console.ReadLine());
            string[] input = Console.ReadLine().Split(' ');
            List<int> toInt = new List<int>();

            //数値に変換
            for (int i = 0; i < number; i++)
            {
                toInt.Add(int.Parse(input[i]));
            }

            int count = 0;
            bool flag = true;

            //変換回数カウント
            while (flag)
            {
                for (int i = 0; i < number; i++)
                {
                    if (toInt[i] % 2 == 0)
                    {
                        toInt[i] = toInt[i] / 2;
                    }
                    else
                    {
                        flag = false;
                        break;
                    }
                }
                count++;
            }

            //出力
            Console.WriteLine(count - 1);
        }
    }
}

N個の配列の動的確保の仕方が分からないので、Listくんに頑張ってもらいました。学校の授業でC言語しかやってなかったので、List型くんが便利過ぎてやばい。やってることは入力したやつを全部割ってるだけですね。

ABC087B - Coins

ABC087B - Coins

using System;

namespace ABC087B
{
    class Program
    {
        static void Main(string[] args)
        {
            int a = int.Parse(Console.ReadLine());
            int b = int.Parse(Console.ReadLine());
            int c = int.Parse(Console.ReadLine());
            int x = int.Parse(Console.ReadLine());
            int count = 0;

            for (int i = 0; i <= a; ++i)
            {
                for (int j = 0; j <= b; ++j)
                {
                    for (int k = 0; k <= c; ++k)
                    {
                        if (x == i * 500 + j * 100 + k * 50)
                        {
                            count++;
                        }
                    }
                }
            }

            Console.WriteLine(count);
        }
    }
}

総当たり作戦!ポイントなのが、for(int i = 0; i<n; i++)じゃなくてfor(int i = 0; i<=n; ++i)になってるところ。

ABC083B - Some Sums

ABC083B - Some Sums

using System;

namespace ABC083B___Some_Sums
{
    class Program
    {
        static void Main(string[] args)
        {
            string[] input = Console.ReadLine().Split(' ');
            int N = int.Parse(input[0]);
            int A = int.Parse(input[1]);
            int B = int.Parse(input[2]);
            int num = 0;
            int[] buff = { };
            int intbuff = 0;
            string str;
            char[] c;

            for (int i = 1; i <= N; i++)
            {
                str = i.ToString();
                c = str.ToCharArray();

                foreach (var item in c)
                {
                    intbuff += int.Parse(item.ToString());
                }

                if(intbuff >= A && intbuff <= B)
                {
                    num += i;
                }

                intbuff = 0;
            }

            Console.WriteLine(num);
        }
    }
}

何してたのかよくわからなくなったから誰か解説して。

ABC088B - Card Game for Two

ABC088B - Card Game for Two

using System;
using System.Collections.Generic;

namespace ABC088B___Card_Game_for_Two
{
    class Program
    {
        static void Main(string[] args)
        {
            int N = int.Parse(Console.ReadLine());
            string[] input = Console.ReadLine().Split(' ');
            List<int> numbers = new List<int>();
            int Alice = 0;
            int Bob = 0;

            //数値に変換
            for (int i = 0; i < N; i++)
            {
                numbers.Add(int.Parse(input[i]));
            }

            //降順にソート
            numbers.Sort();
            numbers.Reverse();

            for (int i = 0; i < N; i++)
            {
                if(i % 2 == 0)
                {
                    Alice += numbers[i];
                }
                else
                {
                    Bob += numbers[i];
                }
            }
            
            Console.WriteLine(Alice - Bob);
        }
    }
}

最適なもの=一番でかいのから取るってことなので、降順にソートして前から取っていけば終わりっ!Listくんほんま神やろ・・・。

ABC085B - Kagami Mochi

ABC085B - Kagami Mochi

using System;
using System.Collections.Generic;

namespace ABC085B___Kagami_Mochi
{
    class Program
    {
        static void Main(string[] args)
        {
            int N = int.Parse(Console.ReadLine());
            List<int> mochiSize = new List<int>();
            for (int i = 0; i < N; i++)
            {
                mochiSize.Add(int.Parse(Console.ReadLine()));
            }

            //降順にソート
            mochiSize.Sort();
            mochiSize.Reverse();

            int maxSize = mochiSize[0];
            int times = 1;
            for (int i = 0; i < N; i++)
            {
                if(maxSize > mochiSize[i])
                {
                    maxSize = mochiSize[i];
                    times++;
                }
            }

            Console.WriteLine(times);
        }
    }
}

なんでダックスフンド鏡餅作るの!?
降順にソートして、下段の餅サイズよりでかかったら1段足してそいつが下段の餅サイズになるを無限に繰り返すだけ。終わりっ!

ABC085C - Otoshidama

ABC085C - Otoshidama

using System;

namespace ABC085C___Otoshidama
{
    class Program
    {
        static void Main(string[] args)
        {
            string[] input = Console.ReadLine().Split(' ');
            int N = int.Parse(input[0]);
            int Y = int.Parse(input[1]);
            bool flag = false;

            for (int i = 0; i < N+1; i++)
            {
                for (int j = 0; j < N-i+1; j++)
                {
                    if(Y== i * 10000 + j * 5000 + (N - i - j) * 1000)
                    {
                        Console.WriteLine($"{i} {j} {N - i - j}");
                        flag = true;
                        goto Exitloop;
                    }
                }
            }

            if (flag == false)
            {
                Console.WriteLine("-1 -1 -1");
            }

            Exitloop:;
        }
    }
}

前から総当たり。組み合わせ見つけたら終わりっ!

[WIP]ABC049C - 白昼夢 / Daydream

ABC049C - 白昼夢 / Daydream

WIPとか使ってみる。これがちょっと詰まってるんよね。まだやり方考え中でどうすればいいかなーってところです。出来たら追記します。

まとめ

はてブのハイライト気持ち悪すぎんか・・・!?
あっついでにgithub使ってみました。フォルダ階層気持ち悪い・・・。
github.com

つよもの採点してくれ~><