基础练习题

2 、 质数求解

2023-09-12  本文已影响0人  北极的大企鹅

   for(int i = 101; i <= 200; i += 2)
   {

   }

这里定义一个变量i,因为是从101开始的,所以初始值设置为101,到200,就是小于等于200,因为是质数,每次都是增加2,所以写作i+=2,就是i=i+2

根据以上描述可得,素数的数,都是可以跟自己整除的数,所以运用取莫运算,因为取莫运算可以得到0和1,0和1可以判断真假,从而得出是否为质数,

可以用101到200之间的数,分别除以一个数,得1的就是质数,得0的就是其他数,这样一直判断下去,这样就又形成一个判断区间,就是多次取莫

因为最小的质数是2,所以从2开始,到根号200结束,每次加一

2~√200 区间(至于为什么是√200,可以百度一下,为什么素数需要根号判断,这是一个数学问题,请问数学老师)这里只说,可以提高效率
得到循环


 for(int j = 2; j <= √200; j++)
 {
     if(i % j == 0)
     {


     if(是质数)
     {
         count++;
     }

思路就是如此,我这里用了集合,最后数值放入一个集合中显示,如果还是不清楚,代码复制入编译器,然后run一下.


 @SuppressWarnings( { "unchecked", "rawtypes" })
 public class _002101_200PrimeNumber
 {
     public static void main(String[] args)
     {
         countZhiShu();
     }
     private static void countZhiShu()
     {
         // 计算变量
         int count = 0;
         // 集合,用来装所有的素数 
         Vector v = new Vector();
         for(int i = 101; i <= 200; i += 2)
         {
             // 判断依据
             boolean b = false;
             for(int j = 2; j < Math.sqrt(i); j++)
             {
                 // 求余数是否为0  
                 if(i % j == 0)
                 {
                     // 如果为0, 将标签设置为false    
                     b = false;
                     // 可以整除就跳出这个循环                
                     break;
                 }
                 else
                 {
                     b = true;
                 }
             }
             if(b == true)
             {
                 //  素数个数加1  
                 count++;
                 // 将符合要求的i加到集合里 
                 v.add(i);
             }
         }
         System.out.println("100到200中间有 " + count + " 个素数");
         System.out.println("素数为:\n" + v);
     }
 }


上一篇 下一篇

猜你喜欢

热点阅读