算法 - 高精度算法(加减乘除)

高精度加法

算法思路

  1. 用a、b两个字符串存储
  2. 将a、b逆序存储到int类型的数组中,A、B
  3. 新建数组C,用于保存结果;新建整数t=0,保存进位
  4. 将各个位上的数字进行相加,得出每一位的结果和进位值

代码模板

package main

import (
	"fmt"
	"strconv"
)

func Add(A, B []int) string {
	// 让A的长度大于B
	if len(A) < len(B) {
		return Add(B, A)
	}

	C := make([]int, 0)
	t := 0
	for i := 0; i < len(A) || t > 0; i++ {
        if i < len(A) {
            t += A[i]
        }
		if i < len(B) {
			t += B[i]
		}
		C = append(C, t%10)
		t /= 10
	}

	var res = ""
	// 转为结果字符串
	for i := len(C) - 1; i >= 0; i-- {
		res += strconv.Itoa(C[i])
	}
	return res
}

func main() {
	var a, b string
	fmt.Scanf("%s %s", &a, &b)
	A, B := make([]int, len(a)), make([]int, len(b))
	for i := len(a) - 1; i >= 0; i-- {1 2
		A[len(a)-1-i] = int(a[i] - 48)
	}
	for i := len(b) - 1; i >= 0; i-- {
		B[len(b)-1-i] = int(b[i] - 48)
	}
	fmt.Println(Add(A, B))
}

高精度减法

算法思路

  • 和高精度加法差不多
  • 新建整数t=0,用于保存借位
  • 将各个位置上的数进行相减,得出每一位的结果和借位值

代码

package main

import (
	"fmt"
)

// 判断是否有A>=B
func cmp(A, B []int) bool {
	if len(A) != len(B) {
		return len(A) > len(B)
	}

	for i := 0; i < len(A); i++ {
		if A[i] != B[i] {
			return A[i] > B[i]
		}
	}
	return true
}

func Sub(A, B []int) {
	C := make([]int, 0)

	for i, t := 0, 0; i < len(A); i++ {
		t = A[i] - t
		if i < len(B) {
			t -= B[i]
		}
		C = append(C, (t+10)%10)
		if t >= 0 {
			t = 0
		} else {
			t = 1
		}
	}
	for len(C) > 1 && C[len(C)-1] == 0 {
		C = C[:len(C)-1]
	}
	for i := len(C) - 1; i >= 0; i-- {
		fmt.Print(C[i])
	}
}

func main() {
	var a, b string
	fmt.Scanf("%s %s", &a, &b)
	A, B := make([]int, len(a)), make([]int, len(b))
	for i := len(a) - 1; i >= 0; i-- {
		A[len(a)-1-i] = int(a[i] - 48)
	}
	for i := len(b) - 1; i >= 0; i-- {
		B[len(b)-1-i] = int(b[i] - 48)
	}

	if cmp(A, B) {
		Sub(A, B)
	} else {
		fmt.Print("-")
		Sub(B, A)
	}
}

需要注意的点

  • 相减为负数的处理
    • 需要对a,b的大小进行判断。若a>=b则为正整数,无需处理;若a<b则为负数,需要在输出时加前导"-"
  • 前导0的处理
    • 在得出逆序的结果数组C后,需要将后边多余的0去掉,但要注意结果为0的情况

代码技巧

相减后t的处理

  • t>=0时,结果为t;当t<0时,结果为10-t(因为借了10)
  • 改写为t=(t+10)%10。用一个式子便可表示。

两个高精度数的大小比较

  • 比较两个数的位数,位数多的数一定大
  • 两个数从前往后比较,若比较的当前位不同,则结果为两者的大小结果

拓展

A B可以为正数或负数该怎么处理?

绝对值相减相加,判断字符串首字符的类型。

  • 正正:直接计算
  • 正负:转化为高精度加法
  • 负负:高精度加法,加前导-

高精度减法

算法思路

  • 和高精度加法差不多
  • 新建整数t=0,用于保存借位
  • 将各个位置上的数进行相减,得出每一位的结果和借位值

代码

package main

import (
	"fmt"
)

// 判断是否有A>=B
func cmp(A, B []int) bool {
	if len(A) != len(B) {
		return len(A) > len(B)
	}

	for i := 0; i < len(A); i++ {
		if A[i] != B[i] {
			return A[i] > B[i]
		}
	}
	return true
}

func Sub(A, B []int) {
	C := make([]int, 0)

	for i, t := 0, 0; i < len(A); i++ {
		t = A[i] - t
		if i < len(B) {
			t -= B[i]
		}
		C = append(C, (t+10)%10)
		if t >= 0 {
			t = 0
		} else {
			t = 1
		}
	}
	for len(C) > 1 && C[len(C)-1] == 0 {
		C = C[:len(C)-1]
	}
	for i := len(C) - 1; i >= 0; i-- {
		fmt.Print(C[i])
	}
}

func main() {
	var a, b string
	fmt.Scanf("%s %s", &a, &b)
	A, B := make([]int, len(a)), make([]int, len(b))
	for i := len(a) - 1; i >= 0; i-- {
		A[len(a)-1-i] = int(a[i] - 48)
	}
	for i := len(b) - 1; i >= 0; i-- {
		B[len(b)-1-i] = int(b[i] - 48)
	}

	if cmp(A, B) {
		Sub(A, B)
	} else {
		fmt.Print("-")
		Sub(B, A)
	}
}

需要注意的点

  • 相减为负数的处理
    • 需要对a,b的大小进行判断。若a>=b则为正整数,无需处理;若a<b则为负数,需要在输出时加前导"-"
  • 前导0的处理
    • 在得出逆序的结果数组C后,需要将后边多余的0去掉,但要注意结果为0的情况

代码技巧

相减后t的处理

  • t>=0时,结果为t;当t<0时,结果为10-t(因为借了10)
  • 改写为t=(t+10)%10。用一个式子便可表示。

两个高精度数的大小比较

  • 比较两个数的位数,位数多的数一定大
  • 两个数从前往后比较,若比较的当前位不同,则结果为两者的大小结果

拓展

A B可以为正数或负数该怎么处理?

绝对值相减相加,判断字符串首字符的类型。

  • 正正:直接计算
  • 正负:转化为高精度加法
  • 负负:高精度加法,加前导-

高精度除法

算法思路

  • 创建整型变量r保存余数
  • 遍历数组A,当前的被除数就是r*10+A[i]`
  • 将商加入结果数组C,余数即被除数对除数b取余的结果

代码模板

package main

import (
	"fmt"
)

func div(A []int, b int) ([]int, int) {
	C := make([]int, 0)
	r := 0
	for i := len(A) - 1; i >= 0; i-- {
		r = r*10 + A[i]
		C = append(C, r/b)
		r %= b
	}
	// 去前导0
	for len(C) > 1 && C[0] == 0 {
		C = C[1:]
	}

	return C, r
}

func main() {
	var a string
	var b int
	fmt.Scanf("%s %d", &a, &b)
	A := make([]int, len(a))
	for i := len(a) - 1; i >= 0; i-- {
		A[len(a)-1-i] = int(a[i] - 48)
	}

	C, r := div(A, b)
	for i := 0; i < len(C); i++ {
		fmt.Print(C[i])
	}
	fmt.Println()
	fmt.Print(r)
}

高精度乘法

高精度×低精度

算法思路

  • 与高精度加法类似
  • 新建整型变量t,用于保存进位
  • 让A上的每一位数字与b相乘

代码

package main

import (
	"fmt"
)

func mul(A []int, b int) []int {
	C := make([]int, 0)
	t := 0
	for i := 0; i < len(A) || t > 0; i++ {
		if i < len(A) {
			t += A[i] * b
		}
		C = append(C, t%10)
		t /= 10
	}
	return C
}

func main() {
	var a string
	var b int
	fmt.Scanf("%s %d", &a, &b)
	A := make([]int, len(a))
	for i := len(a) - 1; i >= 0; i-- {
		A[len(a)-1-i] = int(a[i] - 48)
	}
	C := mul(A, b)
	for i := len(C) - 1; i >= 0; i-- {
		fmt.Print(C[i])
	}
}

高精度×高精度

算法思路

  • 新建整型数组C,大小为len(A)+len(B),存储每一位相乘然后再相加的结果(C[i+j]+=A[i]*B[j])
  • 遍历数组C,进行进位
  • 前导0

代码

package main

import (
	"fmt"
)

func mul(A, B []int) []int {
	C := make([]int, len(A)+len(B))
	// 计算每一位的结果
	for i := 0; i < len(A); i++ {
		for j := 0; j < len(B); j++ {
			C[i+j] += A[i] * B[i]
		}
	}

	//进行进位
	for i, t := 0, 0; i < len(C); i++ {
		t += C[i]
		C[i] = t % 10
		t /= 10
	}

	// 去掉前导0
	for len(C) > 1 && C[len(C)-1] == 0 {
		C = C[:len(C)-1]
	}
	return C
}

func main() {
	var a, b string
	fmt.Scanf("%s %s", &a, &b)
	A, B := make([]int, len(a)), make([]int, len(b))
	for i := len(a) - 1; i >= 0; i-- {
		A[len(a)-1-i] = int(a[i] - 48)
	}
	for i := len(b) - 1; i >= 0; i-- {
		B[len(b)-1-i] = int(b[i] - 48)
	}
	C := mul(A, B)
	for i := len(C) - 1; i >= 0; i-- {
		fmt.Print(C[i])
	}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/901922.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

软件设计师考试大纲整理

为了防止出题者不按常理出牌&#xff0c;此文档为根据上午题大纲自行整理的扩展知识&#xff0c;并非考试常考题 此文档为根据上午题大纲自行整理的扩展知识&#xff0c;并非考试常考题 此文档为根据上午题大纲自行整理的扩展知识&#xff0c;并非考试常考题 闲暇时间了解知…

Web高级开发实验:EL基本运算符与数据访问

一、实验目的 掌握EL的定义&#xff0c;即Expression Language&#xff0c;用于提高编程效率。学习和掌握在开发环境中创建Java文件&#xff0c;并在jsp文件中使用EL表达式去调用其中的方法与属性等。 二、实验所用方法 上机实操 三、实验步骤及截图 1、创建javaweb项目&a…

力扣刷题(sql)--零散知识点(1)

通过一段时间的刷题&#xff0c;感觉自己的sql能力逐渐上去&#xff0c;所以不会像前三道题一样讲那么详细了&#xff0c;这里主要会讲到一些特殊的知识点和方法。另外&#xff0c;我的建议是做完一个题有好的想法赶紧记录下来&#xff0c;不要想着最后汇总&#xff0c;不然会懒…

基于SSM平面设计课程在线学习系统的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;学生管理&#xff0c;教师管理&#xff0c;课程类型管理&#xff0c;课程学习管理&#xff0c;试题讲解管理&#xff0c;作业信息管理 前台账号功能包括&#xff1a;系统首页&#xff0c;个人中心&…

Vue3实现获取验证码按钮倒计时效果

Vue3实现获取验证码按钮倒计时效果 效果描述&#xff1a;用户点击获取验证码按钮&#xff0c;发送请求给后端&#xff0c;按钮失效&#xff0c;并且开始倒计时60秒&#xff1b;在此期间&#xff0c;用户无法再次点击按钮&#xff0c;即使用户刷新页面&#xff0c;倒计时依然存在…

Java项目实战II基于微信小程序的马拉松报名系统(开发文档+数据库+源码)

目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末 一、前言 马拉松运动…

XQT_UI 组件|01|颜色

介绍 XColor 是一个用于处理颜色的类&#xff0c;提供了获取颜色和样式的方法。它可以与 Qt 的 UI 组件结合使用&#xff0c;以便在应用程序中实现丰富的颜色效果。 安装 确保你已经在项目中包含了 xqt_color_palette.hpp 和相关的头文件。 #include "xqt_color_palet…

【Go语言】Gin框架的简单基本文档

思维导图 一、go 原生的http服务 在go中写一个web服务非常方便和快速&#xff1a; package mainimport ("encoding/json""fmt""io""net/http" )type Response struct {Code int json:"code"Data any json:"dat…

Spring中配置文件方式来配置实现数据源

我的后端学习大纲 我Spring学习大纲 1.1.数据源&#xff08;连接池&#xff09;的作用&#xff1a; 1.数据源&#xff08;连接池&#xff09;是提高程序性能而出现的2.数据源的使用步骤 &#xff1a; 创建数据源对象&#xff0c;在对象创建的时候会初始化部分连接资源使用连接…

【jvm】堆的内部结构

目录 1. 说明2. 年轻代&#xff08;Young Generation&#xff09;2.1 说明2.2 Eden区2.3 Survivor区 3. 老年代&#xff08;Old Generation&#xff09;3.1 说明3.2 对象存放3.3 垃圾回收 4. jdk7及之前5. jdk8及之后 1. 说明 1.JVM堆的内部结构主要包括年轻代&#xff08;You…

录屏软件推荐,4个工具助你高效录屏。

不同的录屏软件具有不同的特点和优势&#xff0c;如果只是偶尔需要录制&#xff0c;Win10 自带的录制功能就很方便&#xff1b;如果需要更加专业的录制和编辑功能&#xff0c;我可以推荐几款功能更加多样也效果较好的第三方软件。 1、福昕高清录屏 直达&#xff1a;www.foxits…

SVM(支持向量机)

SVM&#xff08;支持向量机&#xff09; 引言 支持向量机(Support Vector Machine,SVM)&#xff0c;可以用来解答二分类问题。支持向量(Support Vector)&#xff1a;把划分数据的决策边界叫做超平面&#xff0c;点到超平面的距离叫做间隔。在SVM中&#xff0c;距离超平面最近…

基于neo4j的新冠治疗和新冠患者轨迹的知识图谱问答系统

毕业设计还在苦恼选题&#xff1f;想做一个兼具前沿性和实用性的技术项目&#xff1f;了解下这款基于Neo4j的新冠治疗和患者轨迹的知识图谱问答系统吧&#xff01; 系统可以实现两大功能模块&#xff1a;新冠医疗信息和患者活动轨迹的展示与问答。通过图谱技术&#xff0c;你可…

VBA技术资料MF219:创建一个新的类型模块

我给VBA的定义&#xff1a;VBA是个人小型自动化处理的有效工具。利用好了&#xff0c;可以大大提高自己的工作效率&#xff0c;而且可以提高数据的准确度。“VBA语言専攻”提供的教程一共九套&#xff0c;分为初级、中级、高级三大部分&#xff0c;教程是对VBA的系统讲解&#…

【方波转正弦波谐波二阶】2022-6-10

缘由怎么用555时基电路将方波转换为正弦波&#xff1f;-其他-CSDN问答 可参带通滤波器电路图大全&#xff08;三款带通滤波器电路设计原理图详解&#xff09; - 全文 - 应用电子电路 - 电子发烧友网

《关于构图问题》

这是一本讲绘画技巧的书&#xff0c;但仔细琢磨体现出不易察觉的东方哲学思想。中国画讲究意境与留白&#xff0c;留白不代表“空”&#xff0c;而是代表对“实”的延伸&#xff0c;留下瞎想空间&#xff0c;实现对“有限&#xff08;实&#xff09;”的超越。 总论 文艺是人们…

演员王丹妮化身岛屿姐姐 开启少年们的欢乐挑战之旅

全民海岛真人秀《岛屿少年》正在持续热播中&#xff0c;少年们迎来了“茶嵛饭后”⻩⻥馆的开业日&#xff0c;知名演员王丹妮以岛屿姐姐的身份&#xff0c;悄然降临此地&#xff0c;为岛屿少年们带来了一场别开生面的考验。 在餐厅正式开业前夕&#xff0c;王丹妮巧妙地伪装成普…

【Spark+Hive大数据】基于spark抖音数据分析预测舆情系统(完整系统源码+数据库+开发笔记+详细部署教程)✅

目录 【SparkHive大数据】基于spark抖音数据分析预测舆情系统&#xff08;完整系统源码数据库开发笔记详细部署教程&#xff09;✅ 一、项目背景 二、研究目的 三、项目意义 四、项目功能 五、项目创新点​​​​​​​ 六、算法介绍 七、项目展示 八、启动文档 九、…

Android Kotlin中协程详解

博主前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住也分享一下给大家&#xff0c; &#x1f449;点击跳转到教程 前言 Kotlin协程介绍&#xff1a; Kotlin 协程是 Kotlin 语言中的一种用于处理异步编程的机制。它提供了一…

Chromium127调试指南 Windows篇 - 安装C++扩展与配置(五)

前言 在前面的文章中&#xff0c;我们已经安装了Visual Studio Code&#xff08;VS Code&#xff09;并配置了基本的扩展。现在&#xff0c;我们将进一步优化我们的开发环境&#xff0c;重点关注C相关的依赖扩展。这些扩展对于在VS Code中高效开发和调试Chromium项目至关重要。…