四则运算法则在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位转换成相应的 ...
随机推荐
- strong vs copy
一.前言 在这里,我通过实例去介绍strong和copy的区别(%p打印出来对象的地址) ViewController.h #import <UIKi ...
- 回文数的golang实现
判断一个整数是否是回文数.回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数 输入: 输出: true 输入: - 输出: false 解释: 从左向右读, 为 - . 从右向左读, 为 - ...
- Python 如何删除列表中的空值
今天在获取android性能CPU测试数据时,发现这么一个问题: # -*- coding:utf-8 -*- import os import time cpuInfo = os.popen(r'a ...
- centos7下安装docker(3.1创建镜像commit)
docker commit创建镜像 步骤:1.运行容器 2.修改容器 3.将容器保存为镜像 1. 注:-it是以交互模式进入容器,并打开终端 2.安装一个vim进行修改镜像 yum install - ...
- day14 Python函数
函数def,严格来讲有个return返回值 过程就是没有return返回值的函数 #过程 def test01(): msg = 'liuhaoran' print(msg) #函数 def test ...
- js MD5加密处理
关于MD5: MD5.js是通过前台js加密的方式对用户信息,密码等私密信息进行加密处理的工具,也可称为插件. 在本案例中 可以看到MD5共有6种加密方法: 1, hex_md5(value) 2, ...
- Java并发(二)异步转同步
目录 前置条件:构造一个异步调用 一.使用wait和notify方法 二.使用条件锁 三.Future 四.使用CountDownLatch 五.使用CyclicBarrier 总结 在Java并发编 ...
- Django ORM相关
1. ORM 外键关联查询和多对多关系正反向查询 Class Classes(): name = CF class Student(): name = CF class = FK(to="C ...
- I2C总线通信
UART 属于异步通信,比如电脑发送给单片机,电脑只负责把数据通过TXD 发送出来即可,接收数据是单片机自己的事情.而 I2C 属于同步通信, SCL 时钟线负责收发双方的时钟节拍, SDA 数据线负 ...
- 【Codeforces 3D】Least Cost Bracket Sequence
Codeforces 3 D 题意:有一个括号序列,其中一些位置是问号,把第\(i\)个问号改成(需要\(a_i\)的代价,把它改成)需要\(b_i\)的代价. 问使得这个括号序列成立所需要的最小代价 ...