結果
問題 |
No.412 花火大会
|
ユーザー |
![]() |
提出日時 | 2016-08-13 12:59:27 |
言語 | C#(csc) (csc 3.9.0) |
結果 |
AC
|
実行時間 | 30 ms / 2,000 ms |
コード長 | 1,202 bytes |
コンパイル時間 | 2,341 ms |
コンパイル使用メモリ | 105,344 KB |
実行使用メモリ | 19,200 KB |
最終ジャッジ日時 | 2024-11-07 16:36:57 |
合計ジャッジ時間 | 3,353 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 18 |
コンパイルメッセージ
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.Linq; class Program { static string ReadLine() { return Console.ReadLine(); } static int ReadInt() { return int.Parse(ReadLine()); } static int[] ReadInts() { return ReadLine().Split().Select(int.Parse).ToArray(); } static string[] ReadStrings() { return ReadLine().Split(); } static int Calc(int[] bcd, int n, int[] xs) { Array.Sort(bcd); Array.Sort(xs); var dp = new int[n + 1, 4]; dp[0, 0] = 1; for (int i = 0; i < xs.Length; i++) { // i 番目のレジャーシート for (int j = 0; j <= 3; j++) { dp[i + 1, j] += dp[i, j]; // i 番目を選択しない // i 番目を選択する if (j < 3 && bcd[j] <= xs[i]) { dp[i + 1, j + 1] += dp[i, j]; } else { dp[i + 1, j] += dp[i, j]; } } } return dp[n, 3]; } static void Main() { var bcd = ReadInts(); int n = ReadInt(); var xs = ReadInts(); var ans = Calc(bcd, n, xs); Console.WriteLine(ans); } }