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. (1.9)SQL优化——mysql导入导出优化

    (1.9)SQL优化——mysql导入导出优化 1.大批量插入数据 [1.1]MyISAM: (1)如果存在表且有数据,插入前先关闭所有非唯一索引. (2)如果表是空的,默认就是先导入数据再创建索引, ...

  2. what's the 爬虫之基本原理

    what's the 爬虫? 了解爬虫之前,我们首先要知道什么是互联网 1.什么是互联网? 互联网是由网络设备(网线,路由器,交换机,防火墙等等)和一台台计算机连接而成,总体上像一张网一样. 2.互联 ...

  3. pt-table-checksum 使用实践

    在另外部署的机器上执行:      pt-table-checksum h='192.168.122.47',u='root',p='cc.123',P=3306 -d cat --nocheck-r ...

  4. Linux软件包的安装(rpm+yum)

    概述: 1.rpm软件包管理命令软件包的获取a.光盘镜像中有很多软件包可以使用:先挂载光盘,再查看软件包b.从软件的官网获取 .rpm 安装rpm包 ipm -ivh 软件包名称删除rpm包 ipm ...

  5. 【剑指offer】最小的K个数

    一.题目: 输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,. 二.思路: 一群大牛在讨论用噼里啪啦各种排序,复杂度一般也都是O ...

  6. [py]软件编程知识骨架+py常见数据结构

    认识算法的重要性 - 遇到问题? 学完语言,接到需求,没思路? 1.学会了语言,能读懂别人的代码, 但是自己没解决问题的能力,不能够把实际问题转换为代码,自己写出来.(这是只是学会一门语言的后果),不 ...

  7. Notes for Neural Network Methods for Natural Language Processing

    什么是深度学习?   一种机器学习算法,based on [多层][非线性变换]的[神经网络]结构 优点:可以使用 低维 稠密 连续 的向量表示不同粒度的语言单元, 还可以使用循环.卷积.递归等神经网 ...

  8. openshift 容器云从入门到崩溃之三《安装openshift》

    准备好环境,在安装之前请先了解openshift提供的ansible有大量的安装选项 文档地址:https://docs.okd.io/latest/install/configuring_inven ...

  9. socket发送http报文的疑惑(求高手指点一二)

    给8080或80端口的服务端(自己写的serverSocket服务端)发送字符串,此字符串按照http协议拼接而成,既是所谓的http报文.服务端接受成功.如果在报头与消息体之间少了“\r\n\r\n ...

  10. react 全局公共组件-----动态弹窗 (dialog)

    react 的时候,总是会用到弹窗,并且各种各样的,一般来说,组件层级嵌套之后,就会出现 z-index层级覆盖的问题 这个时候,就需要一个公共的弹出层,然后我们将需要展示的组件,放到弹出层里面 下面 ...