计算有理数java_用java具体代码实现分数(即有理数)四则运算

2023-10-30 03:59

本文主要是介绍计算有理数java_用java具体代码实现分数(即有理数)四则运算,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

用java具体代码实现分数(即有理数)四则运算

1,背景

Java老师布置了一个关于有理数运算的题目,因为参考书上有基本代码,所以自己主要是对书上代码做了一点优化,使其用户交互性更加友好以及代码封装性更强

2,说明:

分数也称作有理数,是我们很熟悉的一种数。有时希望程序能对分数进行四则运算,而且两个分数四则运算的结果仍然是分数。下面是具体实现

3,java代码具体实现

3.1 运算类封装

package Rational;

import java.util.StringTokenizer;

/**

* @author sunkun

* 分数四则运算

*/

public class Calculator {

int numerator; // 分子

int denominator; // 分母

Calculator(){

}

Calculator(int a,int b){

if(a == 0){

numerator = 0;

denominator = 1;

}

else{

setNumeratorAndDenominator(a,b);

}

}

void setNumeratorAndDenominator(int a, int b){ // 设置分子和分母

int c = f(Math.abs(a),Math.abs(b)); // 计算最大公约数

numerator = a / c;

denominator = b / c;

if(numerator<0 && denominator<0){

numerator = - numerator;

denominator = - denominator;

}

}

int getNumerator(){

return numerator;

}

int getDenominator(){

return denominator;

}

int f(int a,int b){ // 求a和b的最大公约数

if(a < b){

int c = a;

a = b;

b = c;

}

int r = a % b;

while(r != 0){

a = b;

b = r;;

r = a % b;

}

return b;

}

Calculator add(Calculator r){ // 加法运算

int a = r.getNumerator();

int b = r.getDenominator();

int newNumerator = numerator * b + denominator * a;

int newDenominator = denominator * b;

Calculator result = new Calculator(newNumerator,newDenominator);

return result;

}

Calculator sub(Calculator r){ // 减法运算

int a = r.getNumerator();

int b = r.getDenominator();

int newNumerator = numerator * b - denominator * a;

int newDenominator = denominator * b;

Calculator result = new Calculator(newNumerator,newDenominator);

return result;

}

Calculator muti(Calculator r){ // 乘法运算

int a = r.getNumerator();

int b = r.getDenominator();

int newNumerator = numerator * a;

int newDenominator = denominator * b;

Calculator result = new Calculator(newNumerator,newDenominator);

return result;

}

Calculator div(Calculator r){ // 除法运算

int a = r.getNumerator();

int b = r.getDenominator();

int newNumerator = numerator * b;

int newDenominator = denominator * a;

Calculator result = new Calculator(newNumerator,newDenominator);

return result;

}

// 封装了具体运算,主要为对输入进行转换,对输出封装

public static void compute(String data1,String operation,String data2){

StringTokenizer fenxi = new StringTokenizer(data1,"/");

int data1_1 = Integer.parseInt(fenxi.nextToken());

int data1_2 = Integer.parseInt(fenxi.nextToken());

fenxi = new StringTokenizer(data2,"/");

int data2_1 = Integer.parseInt(fenxi.nextToken());

int data2_2 = Integer.parseInt(fenxi.nextToken());

Calculator r1 = new Calculator(data1_1,data1_2);

Calculator r2 = new Calculator(data2_1,data2_2);

Calculator result;

int a,b;

if(operation.equals("+")){

result = r1.add(r2);

a = result.getNumerator();

b = result.getDenominator();

System.out.println(data1+" "+operation+" " +data2+" = " + a + "/" + b);

}

if(operation.equals("-")){

result = r1.sub(r2);

a = result.getNumerator();

b = result.getDenominator();

System.out.println(data1+" "+operation+" " +data2+" = " + a + "/" + b);

}

if(operation.equals("*")){

result = r1.muti(r2);

a = result.getNumerator();

b = result.getDenominator();

System.out.println(data1+" "+operation+" " +data2+" = " + a + "/" + b);

}

if(operation.equals("/")){

result = r1.div(r2);

a = result.getNumerator();

b = result.getDenominator();

System.out.println(data1+" "+operation+" " +data2+" = " + a + "/" + b);

}

}

}

3.2 测试类

package Rational;

import java.util.Scanner;

/**

* @author sunkun

* 为了测试分数四则运算

* */

public class TestCal {

public static void main(String[] args) {

// TODO Auto-generated method stub

// 用户输入两分数和运算符

Scanner input = new Scanner(System.in);

System.out.println("请用户输入第一个分数(格式a/b)");

String data1 = input.next();

System.out.println("请用户输入要进行运算的运算符(+-*/)");

String operation = input.next();

System.out.println("请用户输入第二个分数(格式c/d)");

String data2 = input.next();

// 根据用户输入进行具体运算

Calculator cal = new Calculator();

System.out.println("运算结果为:");

cal.compute(data1, operation, data2);

// }

}

}

4,实验结果

467a3c5ebe56c1223ffae926049ae7b5.png

e38c2eb35ab52f83b4fe600f97935e25.png

908cb360ea38b13a39f8d01a97643677.png

ed7c05fec42071267b99bd09a455aeda.png

5,备注

如果您有更好的想法或建议,欢迎留言,大家共同学习,相互提高

有理数进一步运算,包括运算功能扩展,分数与小数之间的互转,会写在另一篇博客中。

这篇关于计算有理数java_用java具体代码实现分数(即有理数)四则运算的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/305433

相关文章

Java中对象的创建和销毁过程详析

《Java中对象的创建和销毁过程详析》:本文主要介绍Java中对象的创建和销毁过程,对象的创建过程包括类加载检查、内存分配、初始化零值内存、设置对象头和执行init方法,对象的销毁过程由垃圾回收机... 目录前言对象的创建过程1. 类加载检查2China编程. 分配内存3. 初始化零值4. 设置对象头5. 执行

SpringBoot整合easy-es的详细过程

《SpringBoot整合easy-es的详细过程》本文介绍了EasyES,一个基于Elasticsearch的ORM框架,旨在简化开发流程并提高效率,EasyES支持SpringBoot框架,并提供... 目录一、easy-es简介二、实现基于Spring Boot框架的应用程序代码1.添加相关依赖2.添

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

SpringBoot中整合RabbitMQ(测试+部署上线最新完整)的过程

《SpringBoot中整合RabbitMQ(测试+部署上线最新完整)的过程》本文详细介绍了如何在虚拟机和宝塔面板中安装RabbitMQ,并使用Java代码实现消息的发送和接收,通过异步通讯,可以优化... 目录一、RabbitMQ安装二、启动RabbitMQ三、javascript编写Java代码1、引入

MySQL8.0设置redo缓存大小的实现

《MySQL8.0设置redo缓存大小的实现》本文主要在MySQL8.0.30及之后版本中使用innodb_redo_log_capacity参数在线更改redo缓存文件大小,下面就来介绍一下,具有一... mysql 8.0.30及之后版本可以使用innodb_redo_log_capacity参数来更改

spring-boot-starter-thymeleaf加载外部html文件方式

《spring-boot-starter-thymeleaf加载外部html文件方式》本文介绍了在SpringMVC中使用Thymeleaf模板引擎加载外部HTML文件的方法,以及在SpringBoo... 目录1.Thymeleaf介绍2.springboot使用thymeleaf2.1.引入spring

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D