浅谈一下大数相除有关思路(图解)与用java代码具体解决方案

本文主要是介绍浅谈一下大数相除有关思路(图解)与用java代码具体解决方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

浅谈一下大数相除有关思路(图解)与用java代码具体解决方案

        PS:接上篇大数相乘博客。两数的正负情况在这就不谈了,只要加一个标记就可以了。此文阅读前提:需在解决了大数相加减和大数相乘的基础上进行。

    在完成了大数相乘的程序后,很自然地想到了在不使用java API的情况下,如何实现两个数相除,两数可以是大数和小数的任意组合,如大数/大数,大数/小数。

 

思路图解1:

    刚开始想到的思路如下,以82/4为例

Step 1:

 

 

     想出了这个想法后,跟老师说了一下,老师说想法不错,但是缺点也很明显,此算法只支持两个大数相除和两个小数相除,对于一个大数与一个小数的情况,不能得到解决。想了想,觉得老师说得很对。按照上面的图解,被除结果即是计算机进行机械重复运算的步数,那么如果重复的步数超出了java基本类型的表示范围,即重复的步数为一个大数,就不会有正确的结果。

    回去想了一天,突然间想明白了,既然问题是:重复步数可能为大数问题,那么完全可以逆向思维啊,跳出大数的框架。中心思想:补零操作。结果用另一种思路的String表示就可以了。如82/4 = 20,我们可以先输出String 型2,再输出String型0,再用’+’把0放在2后面就可以了。

思路图解 2:

以100 / 3为例(大数/小数方法相同,嘿嘿吐舌头,偷懒以100和3为例):

Step 2:

Step 3:

具体代码实现:

做了两个类成员方法函数,分别为①chufa(String,String):String和②chu(String,String):String

①chufa(String,String):String

 

 

    /*大整数除法转换函数*/public static String chufa(String data1,String data2) {int i = 0,j = 0,x = 0,y = 0;String jieguo = "";if(data1.charAt(0) == '-') {data1 = data1.substring(1);//去掉大整数前面的负号x++;}if(data2.charAt(0) == '-') {data2 = data2.substring(1);//去掉大整数前面的负号y++;}while(data1.charAt(i)=='0' && i<data1.length()-1) {i++;}data1 = data1.substring(i);//去掉大整数前面的所有无效的数字0while(j<data2.length()-1 && data2.charAt(j)=='0') {j++;}data2 = data2.substring(j);if( panduan(data2)) {System.out.println("除数不能为0,请重新输入!");System.exit(-1);}else {jieguo = chu(data1,data2);if(x+y==1) {jieguo = "-" + jieguo;}}return jieguo;}


②chu(String,String):String

 

    /*高精度除法函数*/                                                 public static String chu(String data1, String data2) {String jieguo = "";int num = data1.length() - data2.length();if (!compare(data2, data1)) {num = -1;}if (num < 0) {jieguo = "0";} else if (panduan(jianfa(data1, data2))) {jieguo = "1";} else {while (num >= 0) {while (data1.length() > data2.length()) {data2 = data2 + "0";}if (!compare(data2, data1)) {data1 += "0";}for (int i = 9; i > 0; i--) {if (compare(chengfa(data2, String.valueOf(i)), data1)) {data1 = jianfa(data1, chengfa(data2, String.valueOf(i)));// 减去已经除去的字符段jieguo += i;i = 0;}if (i == 1) {jieguo += 0;}}num--;}}return jieguo;}


③panduan(String):boolean  // 因为①②中包含了,所以在此解释一下

    /*大整数判断函数*/public static boolean panduan(String data) { // 判断data是否为0int z=0,num=data.length(),count = 0;while(num>=0) {if(data.charAt(count)!=0) {z++;}num--;}if(z==0) {return true;}else {return false;}}


 

结束语:

    自己的想法和代码如上,如果您觉得想法赞,或者对上述有不理解的地方,再或者有更好的想法,欢迎留言,大家相互交流提高。

 

这篇关于浅谈一下大数相除有关思路(图解)与用java代码具体解决方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF