当前位置: 首页 > 面试题库 >

面试问题:递归生成质数的最快方法是什么?

上官鸿祯
2023-03-14
问题内容

质数的生成很简单,但是递归地找到它并生成(质数)的最快方法是什么?

这是我的解决方案。但是,这不是最佳方法。我认为是O(N * sqrt(N))。如果我错了,请纠正我。

    public static boolean isPrime(int n) {
        if (n < 2) {
            return false;
        } else if (n % 2 == 0 & n != 2) {
            return false;
        } else {
            return isPrime(n, (int) Math.sqrt(n));
        }
    }

    private static boolean isPrime(int n, int i) {
        if (i < 2) {
            return true;
        } else if (n % i == 0) {
            return false;
        } else {
            return isPrime(n, --i);
        }
    }

   public static void generatePrimes(int n){
       if(n < 2) {
            return ;
       } else if(isPrime(n)) {
            System.out.println(n);
       }

       generatePrimes(--n);

   }

   public static void main(String[] args) {

        generatePrimes(200);
   }

问题答案:

对于递归,您应该使用 记忆
来改善递归功能,这意味着如果找到素数将其保存在数组中,并且在isPrime(n)未调用isPrime(n,(int)Math.sqrt(
n))。同样,如果isPrime(n,i)返回true,将其添加到素数列表中,则最好对数组进行排序以进行二进制搜索,在C#中有一个排序列表,然后进行二进制搜索操作[使n个项目的列表取O(n
log n)并且搜索是O(log(n))]我不知道Java [但是您可以实现]。


编辑: 您当前的方法是,O(n sqrt(n))但按照我的要求,它可以按相同顺序排列!但是性能更好,实际上顺序是这样的,O(n sqrt(n) / log (n) + n log(n/log(n)))并且因为log(n)小于n^Epsilon,所以最好这样说,O(n sqrt(n))但是如您所见,它将以更快的速度运行log(n)。

同样最好是i-2不是i-并在启动时进行一些额外的检查以更快地运行算法2 * log(n)。



 类似资料:
  • 机器人可以走三种不同长度的步:1厘米、2厘米、3厘米。编写一个递归算法,找出机器人可以通过的不同方式的数量“d”

  • 问题内容: 我正在用Python建立照片库,希望能够快速为高分辨率图像生成缩略图。 为各种图像源生成高质量缩略图的最快方法是什么? 我应该使用像imagemagick这样的外部库,还是有一种有效的内部方法来做到这一点? 调整大小后的图像的尺寸为(最大尺寸): 质量是一个问题,因为我想保留尽可能多的原始颜色并最大程度地减少压缩伪影。 谢谢。 问题答案: 您想要PIL轻松做到这一点 如果您迫切需要速度

  • 我对这个代码有一些问题 问题1:终止情况究竟如何运作?s.length如何等于0? 问题2:为什么代码需要具有“firstChar”才能反转字符串?为什么当逆转字符串接受0的子字符串而不必添加第一个字符时,代码不起作用?

  • 问题内容: 类似于[a-zA-Z0-9]字符串: na1dopW129T0anN28udaZ 或十六进制字符串: 8c6f78ac23b4a7b8c0182d 长期以来,我的意思是2K和更多字符。 问题答案: 这在我的盒子上大约有200MBps。有明显的改进空间。 您只需要生成所需的字符串即可。显然,您可以在途中或其他情况下调整字符集。 这个模型的好处是,它只是一个,因此您可以使用它制作任何东西。

  • 在我之前的面试中,“你最大的缺点是什么”是非常高频被问到的问题。相对于优点来说,很多人可能更不确定如何描述自己的缺点才不会因此丢掉这个面试机会。 首先,不要说“我是个完美主义者”这种话,听起来在玩心机,不够真诚。我们应该把这个问题的回答组织成一个听起来比较真诚的回答,同时要体现出以下几点: 1、这个缺点并不是这个职位的核心要求。比如你去面一个设计师职位然后你说你设计理论有点缺乏,或者视觉设计能力弱

  • 这个问题很常被问到,很有助于面试官加深对你的了解,同时也帮面试官知道你是否对自己有清晰的认识,知道自己擅长什么。思路是说清楚优点是什么,这个优点怎么形成的,让你得到过什么益处。我简单写了几条大家做参考,注意讲的时候扩展一下。 参考答案: 1、 Process driven,有非常完整的设计流程。这是因为我在职业初期因为设计流程不规范而犯过xxxx错误,这让我意识到培养好的设计流程非常重要。所以我通