1

我有这段代码用于创建一个程序,该程序采用一个范围并将质数输出到控制台。我有一个问题,我正在尝试遍历我构建的数组,因此循环应该只将使用我的方法的返回值的素数值写入控制台。我遇到的问题是我将第二个条件设置为,numArray.Length但它似乎给了我Index out of Range Exception. 我只希望循环遍历所有值,numArray并在确定最后一个值是否为素数时停止。

public struct Prime
{
    public int x;


    // constructor for Prime
    public Prime(int x1)
    {
        x = x1;

    }

    public int IsPrime(int number)
    {
        int i;
        for (i = 2; i * i <= number; i++)
        {
            if (number % i == 0) return 0;
        }
        return 1;
    }
}

class Program
{
    static void Main(string[] args)
    {
        Console.WriteLine("Enter an Integer");
        int num1 = Convert.ToInt32(Console.ReadLine());
        Console.WriteLine("Enter a Second Integer of Greater Value");
    //    int num2 = 0;
        int num2 = Convert.ToInt32(Console.ReadLine());

    /*    if (num2temp > num1)
        {
            num2temp = num2;
        }
        else
        {
            Console.WriteLine("You Did Not Enter An Integer Greater Than the First Integer, Please Enter Your Integers Again.");
            Environment.Exit(0);
        }
    */    int index = 1;
        int[] numArray = new int[num2];
        for (int i = num1; i <= num2; i++)
        {
            numArray[index] = i;

            Console.WriteLine(" index: {0} assignment: {1}", index, i);
            index++;
            Console.WriteLine("index: {0}",index);
        }

        Console.WriteLine("value: {0}", numArray[40]);

    /*    Prime myprime = new Prime();

        if (myprime.IsPrime(numArray[12]) == 1)
        {
            Console.WriteLine("true");
        }
        else
        {
            Console.WriteLine("False");
        } */


        Prime myprime = new Prime();


       int value = 0;
        for (int y = 1; y <= num2; y++)
        {
            if (myprime.IsPrime(numArray[y]) == 1)
            {
                value = numArray[y];
                Console.Write("{0} \t", value);

            }

        } 
4

2 回答 2

3

您当前正在尝试迭代到并包括数组的大小。数组在 C# 中从 0 开始索引。所以这:

int[] numArray = new int[num2];
for (int i = num1; i <= num2; i++)

应该:

for (int i = num1; i < num2; i++)

请注意,要获得第一个元素数组,num1必须为 0,而不是 1。

index同样,您对as的初始分配1应该是0。基本上你需要检查你所有的代码(现在很多代码都被注释掉了,这很令人困惑),并检查你假设数组是基于 1 的任何地方,而不是更改你的代码,因为它们是基于 0 的。

(当然,在某些情况下,您可能只想使数组更大。如果您想要一个逻辑上包含值 1 到 x 的数组,您可以创建一个大小为 x 的数组并从每个索引中减去一个时间,或创建一个大小为 x + 1 的数组。)

于 2013-06-10T06:19:34.707 回答
2

您的索引从 1 开始,但应该从 0 开始:

int index = 0; //CHANGE HERE
int[] numArray = new int[num2];
for (int i = num1; i <= num2; i++)
{
    numArray[index] = i;

    Console.WriteLine(" index: {0} assignment: {1}", index, i);
    index++;
    Console.WriteLine("index: {0}",index);
}

然后这里 y 也应该是 0 并检查它是否小于 num2:

for (int y = 0; y < num2; y++)
{
    if (myprime.IsPrime(numArray[y]) == 1)
    {
        value = numArray[y];
        Console.Write("{0} \t", value);

    }

} 

因为 C# 中的数组索引从 0 开始。

于 2013-06-10T06:18:01.480 回答