//根据定义判断素数---循环n-1次,当n很大时循环n次

public static void main(String[] args) {
        // TODO Auto-generated method stub
        Scanner in = new Scanner(System.in);
        boolean isPrime = true;
        int x = in.nextInt();
        if(x == 1)
        {
            isPrime = false;
        }
        for(int i = 2;i<x;i++)
        {
            if(x%i == 0)
            {
                isPrime = false;
                break;
            }
            
        }
        
        if(isPrime)
        {
            System.out.println(x+"是素数");
        }
        else
        {
            System.out.println(x+"不是素数");
        }
    }

//当n很大时,循环n/2次

public static void main(String[] args) {
        // TODO Auto-generated method stub
        //去掉偶数后,从3到x-1,每次加2
            //如果是偶数,立刻pass掉
            //否则就开始循环
        Scanner in = new Scanner(System.in);
        int x = in.nextInt();
        boolean isPrime = true;
        if(x == 1||x!=2 && x%2 == 0)
        {
            isPrime = false;
        }
        else
        {
            for(int i = 3; i<x ;i = i+2)
            {
                if(x % i == 0)
                {
                    isPrime = false;
                    break;
                }
            }
        }
        
        if(isPrime)
        {
            System.out.println(x+"是素数");
        }
        else
        {
            System.out.println(x+"不是素数");
        }

    }

//循环n的平方根次

public static void main(String[] args) {
        // TODO Auto-generated method stub
        
        //判断x的平方根次
        
        Scanner in = new Scanner(System.in);
        boolean isPrime = true;
        int x = in.nextInt();
        if(x == 1 || x % 2==0 && x!=2 )
        {
            isPrime = false;
        }
        else
        {
            for(int i = 3; i<=Math.sqrt(x); i += 2)
            {
                if( x%i ==0 )
                {
                    isPrime = false;
                    break;
                }
            }
        }
        
        if(isPrime)
        {
            System.out.println(x+"是素数");
        }
        else
        {
            System.out.println(x+"不是素数");
        }

//打印前50个素数

public static void main(String[] args) {
        // TODO Auto-generated method stub
        //打印前50个素数
        int[] primes = new int[50];
        primes[0] = 2;
        int cnt = 1;
        
        out:
        for(int x = 3;cnt<50;x++)
        {
            for(int i = 0;i<cnt;i++)
            {
                if( x%primes[i] == 0)
                {
                    continue out;
                }
            }
            
            //当内层for循环执行完后,若没有执行if内的执行体,则顺序执行当前代码,将x写入数组
            primes[cnt++] = x;
            
        }
        
        for(int k:primes)
        {
            System.out.print(k+" ");
        }
        System.out.println(cnt);
    }

//打印100以内的素数

public static void main(String[] args) {
        // TODO Auto-generated method stub
        //构造100以内的素数表(以计算机的思维)
        boolean[] isPrime = new boolean[100];
        for(int i = 0; i<isPrime.length;i++)
        {
            isPrime[i] = true;
        }
        
        for(int i = 2;i<isPrime.length;i++)
        {
            if(isPrime[i])
            {
                for(int k = 2; i*k<isPrime.length;k++)
                {
                    isPrime[i*k] = false;
                }
            }
        }
        
        for(int i = 2; i<isPrime.length;i++)
        {
            if(isPrime[i])
            {
                System.out.print(i+" ");
            }
        }

    }

java语言 打印素数实例的更多相关文章

  1. JAVA语言的素数判断,随机数,函数调用

    近来刚学JAVA,就从JAVA写起吧,JAVA判别素数,其实方法和C/C++没什么区别,主要就是想谈一下,其中包括的3个点. (1)JAVA语言产生随机数,random函数,定义参数max的作用是给出 ...

  2. java语言打印上三角和下三角,进一步得到九九乘法表

    关于下面两种图形的打印问题 ***** 与 * ****  ** *** *** ** **** *  ***** 一:程序 1.先打印下三角 2.结果 3.后打印上三角 4.结果 二:知识点 1.f ...

  3. java多线程找素数实例

    package ltb20180106; public class FindPrime implements Runnable{ private int prime; private int q; p ...

  4. C语言打印100到200之间的素数

    用C语言打印素数,我们首先要了素数的相关定义:只有1和它本身两个因数的自然数,也就是说除了1和它本身外,不能被其他自然数整除的数就称为素数. 例如:101只能被1 和101 整除:103只能被1 和1 ...

  5. Java实例 Part2:Java语言基础

    Part2:Java语言基础 ** Example01:从控制台接收输入字符 ** 运行结果: 实现代码: import java.util.Scanner; public class Example ...

  6. Java循环和数组练习题:打印素数升级版

    前两天一个小伙伴问了我一个数组的练习题,我一看思路很清晰,就是打印素数加了个数组.没想到写的时候啪啪打脸,终究还是没逃过眼高手低.本来不打算发出来了,因为发出来愈发显得我很菜,最后还是打算分享出来,一 ...

  7. 【Java初探实例篇01】——Java语言基础

    示例系列,将对每节知识辅以实际代码示例,通过代码实际编写,来深入学习和巩固学习的知识点. IDE:intellij IDEA: 语言:Java 本次示例:Java语言基础知识的应用. 创建包day_4 ...

  8. Java 打印程序设计实例

    3.1 打印文本 3.1.1 应用场景 假设我们需要打印一个窗体的某个文本编辑域(可能只有几行,也可能包含多页)的内容,并且每页最多打印 54 行,如何实现呢? 3.1.2 解决方法 基本思路如下:首 ...

  9. 瘋耔java语言笔记

    一◐ java概述                                                                                        1.1 ...

随机推荐

  1. linux(六)__进程与任务控制

    一.程序.进程.线程 1.程序是一个普通文件,是一系列指令和数据的集合,是一个静态的实体,是程序员写好之后存储于外设之上的代码.它是"死"的,而进程和程序都是"活&quo ...

  2. 【原】JAVA SE编码规范

    /* * 编码规范: * 1.所有的命名遵循"见名知意"的原则 * 2.所有的命名不允许使用汉字或拼音 * 3.Java的工程命名建议使用小写,比如:oa.crm.cms... * ...

  3. 简单实用angular.js购物车功能

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  4. jquery 点击查看更多箭头变化,文字变化,超出带滚动条。

    从网上好了好久,没找到自己要的,自己写了一下. <!DOCTYPE html> <html> <head> <meta charset="utf-8 ...

  5. 微软要如何击败Salesforce?Office365、Azure、Dynamics365 全面布局AI | 双语

    微软在上月宣布组建自己的 AI 研究小组.该小组汇集了超过 5000 名计算机科学家和工程师,加上微软内部研究部门,将共同挖掘 AI 技术. 与此同时,亚马逊,Facebook,Google,IBM ...

  6. Oracle forall bulk collect批量数据更新

    对于数据量较大的插入操作可采用此种方法操作,注意: limit减少内存占用,如果数据量较大一次性全部加载到内存中,对PGA来说压力太大,可采用limit的方法一次加载一定数量的数据,建议值通常为100 ...

  7. Oracle数据库,数据的增、删、改、查

    oracle数据库中,数据的增.删.改.查,通过SQL语句实现 SQL:结构化查询语言: 特点:不区分大小写:字符串用单引号引起来:语句结束用分号表示结束: 行注释,在语句的最前面加"--& ...

  8. 数据结构(c语言)之学生信息管理系统

    程序思维导图 代码表示(代码参考:长春大学-牛言涛老师) 如有错误请指出欢迎交流 #include<stdio.h> #include<malloc.h>//动态存储分配函数头 ...

  9. 安卓Socket连接实现连接实现发送接收数据,openwrt wifi转串口连接单片机实现控制

    安卓Socket连接实现连接实现发送接收数据,openwrt wifi转串口连接单片机实现控制 socket 连接采用流的方式进行发送接收数据,采用thread线程的方式. 什么是线程?  详细代码介 ...

  10. LDR、STR指令

    LDR(load register)指令将内存内容加载入通用寄存器 STR(store register)指令将寄存器内容存入内存空间中 #define GPJ0CON 0xE0200240 _sta ...