所以我试图解决这个问题:
您将获得n和2 * n个数字 . 编写程序以检查奇数之和是否等于偶数n的总和 . 第一个数字被认为是奇数,下一个数字被认为是,下一个数字被认为是等等 . 打印结果为“是”或“否” . 如果是,也打印总和 . 如果是,则还打印奇数和偶数之和的差值 . 输入应从控制台读取输入数据 . •第一行包含整数n - 数字的数量 . •接下来的2 * n行中的每一行只包含一个数字 . 输入数据始终有效且采用所述格式 . 无需明确检查 . 输出•必须在控制台上打印输出 . •打印“是,sum = S”,其中S是奇数n个数之和的总和,等于n个数之和等于偶数n个数之和 . •否则打印“No,diff = D”,其中D是奇数n个数之和与偶数n个数之和之差 . D应始终为正数 . 约束•数字n是[0 ... 500]范围内的整数 . •所有其他数字是[-500 000 ... 500 000]范围内的整数 . •允许您的程序工作时间:0.25秒 . •允许的内存:16 MB . “
我目前编写的代码是这样的:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace Odd_and_Even_Sum
{
class Program
{
static void Main(string[] args)
{
int n = int.Parse(Console.ReadLine());
List<string> stringOfNumbers = new List<string>(2*n);
stringOfNumbers.DefaultIfEmpty();
List<int> listOfEvenNumbers = new List<int>(2*n);
List<int> listOfOddNumbers = new List<int>(2*n);
int diff = 0;
for (int i = 0; i < 2*n; i++)
{
stringOfNumbers[i] = Console.ReadLine();
}
List<int> listOfNumber = new List<int>() { 1, 2, 3 };
for (int i = 0; i < 2*n; i++)
{
listOfNumber[i] = int.Parse(stringOfNumbers[i]);
}
foreach (var item in listOfNumber)
{
if (IsEven(item))
{
listOfEvenNumbers.Add(item);
}
else
{
listOfOddNumbers.Add(item);
}
}
int sumOfEven = listOfEvenNumbers.Sum();
int sumOfOdd = listOfOddNumbers.Sum();
if (sumOfEven > sumOfOdd){
diff = sumOfEven - sumOfOdd;
}
if (sumOfEven < sumOfOdd){
diff = sumOfOdd - sumOfEven;
}
if (sumOfEven == sumOfOdd)
{
Console.WriteLine("Yes, sum ={0}", sumOfEven);
}
else
{
Console.WriteLine("No, diff={0}", diff);
}
}
public static bool IsEven(int n)
{
if (n % 2 == 0)
{
return true;
}
else
{
return false;
}
}
}
}
我的代码正在编译,但是当我插入输入值时,我得到这个错误:
未处理的异常:System.ArgumentOutOfRangeException:索引超出范围 . 必须是非负数且小于集合的大小 . 参数名:System.ThrowHelper.ThrowArgumentOutOfRangeException()中的索引,位于C:\ Users \ User1中Odd_and_Even_Sum.Program.Main(String [] args)的System.Collections.Generic.List`1.set_Item(Int32索引,T值) \ Documents \ V isual Studio 2013 \ Projects \ Odd and Even Sum \ Program.cs:第21行
2 回答
当你写作
您正在创建一个新 empty 列表,其中包含 zero element 但具有 initial capacity bound of 2*n . 这意味着 it reserves memory for inserting 2*n elements but it does not have any .
在这里,您尝试访问列表中导致异常的元素,因为列表中没有元素 . 你应该改用
您混淆了添加动态列表元素的方式,并且您在此列表的实例中出错