1,素数输出

设计思路声明两个函数分别用来实现输出任意两个数之间所有的素数和任意两个数之间最大最小的十个素数

方法一:一个数的因子不会大于它本身的开方;

方法二:创建一个数组来储存素数并输出最大最小的十个;

/*

*黄珺瑜    2018.10.13

*/

import java.util.Scanner;

public class PrimePrintf {

// private final int MAX = 10000;

// private boolean a[]=new boolean[MAX];

private int num1=0,num2=0,a=0,m=0;

Scanner cin = new Scanner(System.in);

public void Printf() {  //任意输入两个整数,输出他们之间的所有素数

System.out.print("请输入两个整数:");

num1 = cin.nextInt();

num2 = cin.nextInt();

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

boolean flag = true;

for(int j=2;j<=Math.sqrt(i);j++) {

if(i%j==0) {

flag = false;

break;

}

}

if(flag)

{

a++;

System.out.print(i+"\t");

if(a%5==0)

System.out.println();

}

}

System.out.println();

}

//输出 任意两个数之间的最大十个素数和最小十个素数

public void MaxMin() {

System.out.print("请输入两个整数:");

num1 = cin.nextInt();

num2 = cin.nextInt();

int prime[]= new int[Math.abs(num2-num1)];   //声明一个数组用来储存素数

//按大小顺序储存素数

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

boolean flag = true;

for(int j=2;j<=Math.sqrt(i);j++) {

if(i%j==0) {

flag = false;

break;

}

}

if(flag)

{

prime[m] = i;

m++;

}

}

//输出前十个素数即最小的十个素数

System.out.println("最小的十个素数:");

for(int i=0;i<=9;i++) {

System.out.print(prime[i]+"\t");

if(i==4)System.out.println();

}

//找到最后一个素数即最大的素数的下标,并输出最后十个素数即最大的十个素数

for(int i=0;i<Math.abs(num2-num1);i++)

if(prime[i]==0) {

m=i;

break;}

System.out.println("\t\r最大的十个素数:");

for(int i=m-10;i<=m-1;i++) {

System.out.print(prime[i]+"\t");

if(i==m-6)System.out.println();

}

}

public static void main(String[] args) {

PrimePrintf pri = new PrimePrintf();

pri.Printf();

pri.MaxMin();

}

}

2,递归方法

判断是否是回文即判断前一半字符串等于后一半字符串倒过来即可。

使用回文的方法操作即输入前一半最后面的字符下标然后递归到第一个字符 判断是否等于后一半最后面的字符  然后一直往前比较,看前一半字符是否全等于后一半字符倒过来。

/*

* 黄珺瑜 2018.10.13

*/

import java.util.Scanner;

public class Judge {

public Scanner cin = new Scanner(System.in);

private char a[] = new char[100];

private boolean flag = true;

//使用递归方法判断是否前一半字符与后一半倒数字符都相等

public boolean JudgePlalindrome(int n ,boolean flag) {

if(n==0)

if(a[n]==a[a.length-1-n])

return flag =flag&&true;

else return flag =flag&&false;

else

return JudgePlalindrome(n-1,flag);

}

//输入字符串 并判断输出是否是回文

public void IsOrNot() {

String ss;

ss = cin.nextLine();

a=ss.toCharArray();

if(JudgePlalindrome(a.length-1, flag)) {

System.out.println("该字符串是回文");

}

else

System.out.println("该字符串不是回文");

}

public static void main(String[] args) {

Judge m = new Judge();

m.IsOrNot();

}

}

3,统计分析

声明一个结构体接收文本文件导出的字符串并将其分割然后进行比较如果有单词是相同的话就加一  然后比较哪个单词出现的次数多 并输出;

/*

*黄珺瑜   2018.10.13

*/

import java.io.BufferedReader;

import java.io.File;

import java.io.FileInputStream;

import java.io.IOException;

import java.io.InputStreamReader;

public class Mananger {

private final int MAX = 1000;

private String[] st;

private String s;         //用来转换StringBuilder类型

private words[] a = new words[MAX];       //声明一个类数组

private StringBuilder str=new StringBuilder();    //为了储存从文本中导出的字符串

/*

* 文件内容的导出

*/

public  void output_1() throws IOException

{

File a=new File("information.txt");

FileInputStream b = new FileInputStream(a);

InputStreamReader c=new InputStreamReader(b,"UTF-8");

{

BufferedReader bufr =new BufferedReader(c);

String line = null;

while((line = bufr.readLine())!=null){

st=line.split("[,?!.\":...-;+-]");     //字符串变成字符串数组,设置多个分割符

for(int i=0;i<st.length;i++)

str.append(st[i]+" ");    //将字符串添加到str类中

}

bufr.close();

}

c.close();

b.close();

s=""+str;          //将str转换成String类

st=s.split(" ");    //将s转换成字符串数组

}

/*

* 用来比较字符串数组中哪个单词出现的频率多

*/

public String Competive() throws IOException {

String Max;

output_1();

int m=1;

int max=0;

a[0]=new words();       //每次调用声明的a类数组都必须给它开辟一个空间

a[0].Words=st[0];

a[0].Number = 1;

for(int i=1;i<st.length;i++) {

boolean flag = true;

for(int j=0;j<m;j++) {

if(a[j].Words.equals(st[i])) {   //如果字符串相同则它们出现的次数加一

a[j].Number++;

flag = false;

break;

}

}

if(flag) {   //将不同的字符串传入

m++;

a[m-1]=new words();

while(st[i].equals(" "))

i++;

a[m-1].Words=st[i];

a[m-1].Number = 1;

}

}

for(int n=1;n<m;n++) {    //比较得出出现的次数最多的那个单词

if(a[max].Number<a[n].Number)

max=n;

}

Max = a[max].Words;

return Max;

}

public static void main(String[] args) throws IOException  {

Mananger con = new Mananger();   //声明一个Mananger对象用来调用Competive函数

System.out.println("出现最多的单词是:"+con.Competive());

}

}

ClassTwo__HomeWork的更多相关文章

随机推荐

  1. python实现图片隐藏信息技术

    隐秘通信的3种典型方式: ①将秘密信息隐于网络通信协议中. ②将秘密信息隐于数字签名等密码协议中 . ③将秘密信息隐于数字图像中. 第三种是利用图像或音频数据对人类感官系统的冗余. 隐藏域数字图像中的 ...

  2. 报错解决——OSError: libdarknet.so: cannot open shared object file: No such file or directory

    在python目录下打开终端,输入 python darknet.py 结果报错 Traceback (most recent call last): File “darknet.py”, line ...

  3. 万恶之源 - Python装饰器及内置函数

    装饰器 听名字应该知道这是一个装饰的东西,我们今天就来讲解一下装饰器,有的铁子们应该听说,有的没有听说过.没有关系我告诉你们这是一个很神奇的东西 这个有多神奇呢? 我们先来复习一下闭包 def fun ...

  4. 通过socket实现http通讯代码理解

    1.首先构造http协议报头: String dd = "GET http://www.baidu.com HTTP/1.1" + "\r\n" + " ...

  5. 2019.03.24 Ajax

    也还是会用到jquery中的Ajax请i求 所以第一还是引入jQuery包   可以去网上搜腾讯网静态资源库 然后引入包    Ajax还是异步处理  处理堵塞问题  import time 就可以了 ...

  6. ASP.Net中的四种状态保持机制

    每个人上网可多有过这样的情况,当我们登陆某个网站时,在登陆的旁边会有一个 "记住我" 的复选框,有的网站还会让用户选择记住我.这个记住我是怎么实现的呢? 其实就用利用的是cooki ...

  7. Ubuntu16.04源的问题

    今天执行下列语句 sudo apt-get update报错 安装redis时 sudo apt-get install redis-server报错 报错内容大致如下: 在网上查了一下是源的问题,我 ...

  8. url传输编码

    首先:协议规范,RFC 1738,定义url地址中不能包含除:0-9,a-zA-Z,- 之外的字符,即,如URL中包含特殊字符,如$-_.+!*’(), 都要编码. 关于为什么如此定义,有如下几个原因 ...

  9. Python中self和__init__的含义与使用

    原文地址https://blog.csdn.net/love666666shen/article/details/78189984 Python中的self 在Python中的类Class的代码中,常 ...

  10. 关于原始input的一些事情

    1.关于input type为number时 maxlength失效 <input class="myfrom-input" type="text" id ...