四则运算法则在Java中的实现
软件工程的课程已经上过有一段时间了,前段时间由于比较忙着考试,所以关于四则运算的代码一直没有实现。同时由于近来一段时间一直在自学java,因为C++虽然也是面向对象,而且可以开发很多软件或者程序,但是我觉得java面向对象的程度可以达到95%左右,而C++可能达到80%,因此由于java更加的面向对象,所以本人在近期一段时间学习了一些关于java的知识,由于学习的不深,占时还不能完全面向对象,我想再过段时间,绝对可以做出和网页上出现的一样的面向对象操作。以下是四则运算在java中的运用。具体运行结果如下所示:

此算法可以进行加减法,乘除法以及混合运算,而且自己可以自主选择算法的类型,另外也可以选择几位数的运算,以及根据自己的需要也可以打印多少道题。具体的代码如下所示:
/**
* 作者:曹家铭
* 日期:2016,3,31
* 功能:自动生成四则运算
*/
package com.Caojiaming; import java.util.Scanner; public class Caculator { /**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub System.out.println("0表示结束运算,1代表加减运算,2代表乘除运算,3代表混合运算,请选择:");
Yunsuan bn=new Yunsuan();
Jiajian an=new Jiajian();
Chengchu cn=new Chengchu();
Hunhe dn=new Hunhe();
Scanner in=new Scanner(System.in);
int L=in.nextInt(); if(L==0)
{
bn.Showme();
}
if(L==1)
{
System.out.println("当M=10时表示两位数的加减运算,M=100时表示三位数的加减运算...请选择");
int M=in.nextInt();
an.setM(M);
System.out.println("请输入需要打印多少道题,10的倍数:");
int N=in.nextInt();
an.setN(N);
an.Showme();
}
if(L==2)
{
System.out.println("当M=10时表示两位数的乘除运算,M=100时表示三位数的乘除运算...请选择");
int M=in.nextInt();
cn.setM(M);
System.out.println("请输入需要打印多少道题,10的倍数:");
int N=in.nextInt();
cn.setN(N);
cn.Showme();
}
if(L==3)
{
System.out.println("当M=10时表示两位数的混合运算,M=100时表示三位数的混合运算...请选择");
int M=in.nextInt();
dn.setM(M);
System.out.println("请输入需要打印多少道题,10的倍数:");
int N=in.nextInt();
dn.setN(N);
dn.Showme();
} } }
class Yunsuan
{
public int N;
public int getN() {
return N;
}
public void setN(int n) {
N = n;
}
public int M;
public int getM() {
return M;
}
public void setM(int m) {
M = m;
}
//int a,b;
public void Showme()
{
System.out.println("结束运算。");
}
}
class Jiajian extends Yunsuan
{
public char o[]={'+','-'};
public void Showme()
{
for(int i=0;i<N/10;i++)
{
for(int j=0;j<10;j++)
{
int a=(int)(Math.random()*M)+1;
int b=(int)(Math.random()*M)+1;
int c=(int)(Math.random()*2);
System.out.print(a);
System.out.print(o[c]);
System.out.print(b+"= ");
}
System.out.println();
}
}
}
class Chengchu extends Yunsuan
{
public char p[]={'*','/'};
public void Showme()
{
for(int i=0;i<N/10;i++)
{
for(int j=0;j<10;j++)
{
int a=(int)(Math.random()*M)+1;
int b=(int)(Math.random()*M)+1;
int c=(int)(Math.random()*2);
System.out.print(a);
System.out.print(p[c]);
System.out.print(b+"= ");
}
System.out.println();
}
}
}
class Hunhe extends Yunsuan
{
public char m[]={'+','-','*','/'};
public void Showme()
{
for(int i=0;i<N/10;i++)
{
for(int j=0;j<10;j++)
{
int a=(int)(Math.random()*M)+1;
int b=(int)(Math.random()*M)+1;
int d=(int)(Math.random()*M)+1;
int f=(int)(Math.random()*M)+1;
int c=(int)(Math.random()*4);
int e=(int)(Math.random()*4);
int g=(int)(Math.random()*4);
System.out.print(a);
System.out.print(m[c]);
System.out.print(b);
System.out.print(m[e]);
System.out.print(d);
System.out.print(m[g]);
System.out.print(f+"= ");
}
System.out.println();
}
}
}
四则运算法则在Java中的实现的更多相关文章
- java中的23中设计模式(转)
设计模式(Design Patterns) --可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了 ...
- java中的23中设计模式(转载的,有时间一定要熟读)
设计模式(Design Patterns) --可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了 ...
- Java中的GOF23(23中设计模式)--------- 工厂模式(Factory)
Java中的GOF23(23中设计模式)--------- 工厂模式(Factory) 在给大家介绍工厂模式之前,我想和大家聊聊面向对象的那点事,在这里,引入三个概念. 开闭原则(Open Close ...
- 161027、Java 中的 12 大要素及其他因素
对于许多人来说,"原生云"和"应用程序的12要素"是同义词.本文的目的是说有很多的原生云只坚持了最初的12个因素.在大多数情况下,Java 能胜任这一任务.在本 ...
- hadoop中Text类 与 java中String类的区别
hadoop 中 的Text类与java中的String类感觉上用法是相似的,但两者在编码格式和访问方式上还是有些差别的,要说明这个问题,首先得了解几个概念: 字符集: 是一个系统支持的所有抽象字符的 ...
- Java中的大数处理类BigInteger和BigDecimar浅析
这两个类位于java.math包内,要使用它们必须在类前面引用该包:import java.math.BigInteger;和import java.math.BigDecimal; BigInteg ...
- Java 中的泛型详解-Java编程思想
Java中的泛型参考了C++的模板,Java的界限是Java泛型的局限. 2.简单泛型 促成泛型出现最引人注目的一个原因就是为了创造容器类. 首先看一个只能持有单个对象的类,这个类可以明确指定其持有的 ...
- Java中的线程Thread总结
首先来看一张图,下面这张图很清晰的说明了线程的状态与Thread中的各个方法之间的关系,很经典的! 在Java中创建线程有两种方法:使用Thread类和使用Runnable接口. 要注意的是Threa ...
- Java中byte与16进制字符串的互换原理
我们都知道Java中的byte是由8个bit组成的,而16进制即16中状态,它是由4个bit来表示的,因为24=16.所以我们可以把一个byte转换成两个用16进制字符,即把高4位和低4位转换成相应的 ...
随机推荐
- RBAC权限管理系统数据模型
懒得多写了,懂的看建表脚本就懂了... -- ---------------------------- -- Table structure for ucb_user -- ------------- ...
- Mongodb主从模式SECONDARY提升为PRIMARY
生产环境不建议仅使用PRIMARY-SECONDARY模式 当primary挂掉,并且无法恢复时,可以把secondary提升为主节点. 注意:此时从节点可能有部分数据未同步过来,部分数据可能丢失. ...
- PHP中使用Elasticsearch
PHP中使用Elasticsearch composer require elasticsearch/elasticsearch 会自动加载合适的版本!我的php是5.6的,它会自动加载5.3的ela ...
- LINUX配置过程记录
http://blog.csdn.net/Houchaoqun_XMU/article/details/78869052 64 sudo apt-get update 0 打开终端的快捷键是Ctrl+ ...
- LoadRunner 11安装Micosoft Visual C++ 2005 SP1时提示命令行选项语法错误
如果安装LoadRunner 11时弹窗提示"Micosoft Visual C++ 2005 SP1 可再发行组件包(X86):'命令行选项语法错误.键入命令 / ? 可获得帮助信息'&q ...
- oracle 查询分区表的最大分区以及分区字段的最大值
select 'select max(' || column_name || ') from ' || owner || '.' || name || ';' from DBA_PART_KEY_C ...
- MATLAB——神经网络构造线性层函数linearlayer
% example5_7.m x=-:; y=*x-; randn(); % 设置种子,便于重复执行 y=y+randn(,length(y))*1.5; % 加入噪声的直线 plot(x,y,'o' ...
- PAT A1017 Queueing at Bank (25 分)——队列
Suppose a bank has K windows open for service. There is a yellow line in front of the windows which ...
- npm安装cnpm报错
1.持久使用 npm config set registry https://registry.npm.taobao.org // 配置后可通过下面方式来验证是否成功npm config get re ...
- (转)tcp/ip协议的简单理解 -- ip报文和tcp报文的格式
1.概念: TCP/IP协议通信的过程其实就对应着数据入栈与出栈的过程.入栈的过程,数据发送方每层不断地封装首部与尾部,添加一些传输的信息,确保能传输到目的地.出栈的过程,数据接收方每层不断地拆除首部 ...