Submission #4626826


Source Code Expand

using System;
using System.Collections.Generic;
using System.Linq;
using static System.Console;
using static System.Convert;
using static System.Math;
//using static System.Globalization.CultureInfo;

class Program
{
    static void Main(string[] args)
    {
        var hwab = Input.ar;
        var com = new Calculation.Combination(hwab[0] + hwab[1]);
        var sum = 0L;
        for(var i = hwab[3]; i < hwab[1]; i++)
        {
            sum += (long)com.Comb(hwab[0] - hwab[2] + i - 1, i) * com.Comb(hwab[2] + hwab[1] - i - 2, hwab[1] - i - 1);
            sum %= Input.MOD;
        }
        WriteLine(sum);
    }
}

public class Input
{
    public static string read => ReadLine();
    public  static int[] ar => Array.ConvertAll(read.Split(' '), int.Parse);
    public  static int num => ToInt32(read);
    public static long[] arL => Array.ConvertAll(read.Split(' '), long.Parse);
    public  static long numL => ToInt64(read);
    public static int[][] twodim(int num)
        => Enumerable.Repeat(0, num).Select(v => ar).ToArray();
    public static long[][] twodimL(int num)
        => Enumerable.Repeat(0, num).Select(v => arL).ToArray();
    public  const string Alfa = "abcdefghijklmnopqrstuvwxyz";
    public  const int MOD = 1000000007;
}

public class Calculation
{
    public static int LCM(int num1, int num2)
    {
        return num1 / GCD(num1, num2) * num2;
    }

    public static long LCM(long num1, long num2)
    {
        return num1 / GCD(num1, num2) * num2;
    }

    public static int GCD(int num1, int num2)
    {
        return num1 < num2 ? GCD(num2, num1) :
            num2 > 0 ? GCD(num2, num1 % num2) : num1;
    }

    public static long GCD(long num1, long num2)
    {
        return num1 < num2 ? GCD(num2, num1) :
            num2 > 0 ? GCD(num2, num1 % num2) : num1;
    }

    public static int Multiple(int num1, int num2)
        => (int)(BigMul(num1, num2) % Input.MOD);
    
    public static int Pow(int m,int n)
    {
        if (n == 0) return 1;
        if (n % 2 == 0) return Pow(Multiple(m, m), n / 2);
        else return Multiple(Pow(Multiple(m, m), n / 2), m);
    }

    public static int Div(int a, int b)
        => Multiple(a, Pow(b, Input.MOD - 2));

    public class Combination
    {
        private int[] _fac;
        public Combination(int num)//階乗をメモ化
        {
            _fac = new int[num + 1];
            _fac[0] = 1;
            for (var i = 1; i <= num; i++)
                _fac[i] = Multiple(_fac[i - 1], i);
        }
        public int Comb(int n,int r)
        {
            if (n < r) return 0;
            if (n == r) return 1;
            var calc = _fac[n];
            calc = Div(calc, _fac[r]);
            calc = Div(calc, _fac[n - r]);
            return calc;
        }
    }
}

Submission Info

Submission Time
Task D - Iroha and a Grid
User hibatibati
Language C# (Mono 4.6.2.0)
Score 400
Code Size 2883 Byte
Status AC
Exec Time 343 ms
Memory 13268 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 400 / 400
Status
AC × 4
AC × 26
Set Name Test Cases
Sample subtask0_01.txt, subtask0_02.txt, subtask0_03.txt, subtask0_04.txt
All subtask0_01.txt, subtask0_02.txt, subtask0_03.txt, subtask0_04.txt, subtask1_01.txt, subtask1_02.txt, subtask1_03.txt, subtask1_04.txt, subtask1_05.txt, subtask1_06.txt, subtask1_07.txt, subtask1_08.txt, subtask1_09.txt, subtask1_10.txt, subtask1_max.txt, subtask2_01.txt, subtask2_02.txt, subtask2_03.txt, subtask2_04.txt, subtask2_05.txt, subtask2_06.txt, subtask2_07.txt, subtask2_08.txt, subtask2_09.txt, subtask2_10.txt, subtask2_max.txt
Case Name Status Exec Time Memory
subtask0_01.txt AC 21 ms 11092 KB
subtask0_02.txt AC 21 ms 11092 KB
subtask0_03.txt AC 24 ms 9696 KB
subtask0_04.txt AC 168 ms 9696 KB
subtask1_01.txt AC 21 ms 11220 KB
subtask1_02.txt AC 21 ms 11220 KB
subtask1_03.txt AC 21 ms 11220 KB
subtask1_04.txt AC 22 ms 13268 KB
subtask1_05.txt AC 21 ms 13140 KB
subtask1_06.txt AC 21 ms 9172 KB
subtask1_07.txt AC 21 ms 11220 KB
subtask1_08.txt AC 21 ms 9172 KB
subtask1_09.txt AC 21 ms 11220 KB
subtask1_10.txt AC 21 ms 9172 KB
subtask1_max.txt AC 21 ms 11220 KB
subtask2_01.txt AC 33 ms 11148 KB
subtask2_02.txt AC 23 ms 9096 KB
subtask2_03.txt AC 30 ms 11164 KB
subtask2_04.txt AC 37 ms 11140 KB
subtask2_05.txt AC 31 ms 9108 KB
subtask2_06.txt AC 339 ms 9696 KB
subtask2_07.txt AC 33 ms 9696 KB
subtask2_08.txt AC 207 ms 11744 KB
subtask2_09.txt AC 134 ms 11204 KB
subtask2_10.txt AC 343 ms 9696 KB
subtask2_max.txt AC 38 ms 11132 KB