1

此应用程序将收到一个数字“n”。收到这个数字后,程序必须显示素数列表中的第 n 个素数。例如,如果用户输入“3”,程序应该显示“5”,因为 5 是从 2 开始的第三个素数。我知道我的代码有问题,但我不知道问题出在哪里以及我该如何解决。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("Determinar el n-esimo primo.");
            long n = Convert.ToInt64(Console.ReadLine()); // N lugar de primos
            long[] array = new long[n];
            long c=0;
            while (c >= 2) 
            { 
                if(siprimo(c++) == true)
                    for (long i = 0; i < n; i++)
                    {
                        array[i] = c;
                    }
            }

            Console.WriteLine(array[n - 1]);
            Console.ReadLine();
        }

        static private bool siprimo(long x)
        {
            bool sp = true;
            for (long k = 2; k <= x / 2; k++)
                if (x % k == 0)
                    sp = false;
            return sp;
        }
    }
}
4

3 回答 3

2

这看起来像家庭作业,我不会为你做作业。但是我会告诉你,如果你只是简单地通过你的程序(在 Visual Studio 中使用 F10),这个问题很容易找到。

提示:c 什么时候递增?

于 2010-03-24T05:06:00.710 回答
2

其他一些要问自己的问题:

  • 当找到一个素数(siprime)时,该值存储在哪里?
  • 你循环了多少次while (c >= 2)代码块?
于 2010-03-24T06:03:27.667 回答
0

更像:

int GetAnswer(int nprime) {
   if (nprime == 1) return 2;
   if (nprime == 2) return 3;

   int j;
   int n = 2; 
   int i = 5;

   while (n < nprime)  {

     int isprime = 1;
     double r = Math.Sqrt(i);

     for(j = 3; j <= r;  j+=2)
        if((i%j) == 0) {
           isprime = 0;
           break;
        } 


     n+=isprime; 
     i+=2;
   }
   return i;
 }

在您的程序中,您犯了一些错误,例如:

long c=0;
while (c >= 2) 

C 永远不会大于 2,因此代码永远不会被执行。

于 2010-03-24T16:25:45.773 回答