競技プログラミングの鉄則
次の問題へ
前の問題へ
A37 Travel 2
C#のソース
using System;
using System.Collections.Generic;
using System.Linq;
class Program
{
static string InputPattern = "InputX";
static List<string> GetInputList()
{
var WillReturn = new List<string>();
if (InputPattern == "Input1") {
WillReturn.Add("2 3 100");
WillReturn.Add("10 20");
WillReturn.Add("1 2 3");
//702
}
else {
string wkStr;
while ((wkStr = Console.ReadLine()) != null) WillReturn.Add(wkStr);
}
return WillReturn;
}
static void Main()
{
List<string> InputList = GetInputList();
long[] wkArr = InputList[0].Split(' ').Select(pX => long.Parse(pX)).ToArray();
long B = wkArr[2];
long[] AArr = InputList[1].Split(' ').Select(pX => long.Parse(pX)).ToArray();
long[] CArr = InputList[2].Split(' ').Select(pX => long.Parse(pX)).ToArray();
long Answer = 0;
long ACnt = AArr.Length;
long CCnt = CArr.Length;
// 駅ごとに、バスの数だけ加算
foreach (long EachA in AArr) {
Answer += EachA * CCnt;
}
// 駅の数 * バスの数 のBを加算
Answer += B * ACnt * CCnt;
// バスごとに、駅の数だけ加算
foreach (long EachC in CArr) {
Answer += EachC * ACnt;
}
Console.WriteLine(Answer);
}
}
解説
それぞれを個別で、何回足されるかを考えてます。