高精度计算----减法运算

2024-09-07 19:18
文章标签 计算 运算 高精度 减法

本文主要是介绍高精度计算----减法运算,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

处理大数减法运算:

1、首先要判断被减数与减数哪个更大,再相应的带入减法函数去处理。具体的比较可以使用字符串的相关知识去比较。

2、相减要先对齐数组,依照减数的长度,执行相应的减法运算次数。

3、不需要借位相减的话,直接减去;需要的话,向前借一位,若前一位是0,则再前借(此时前一位的0变为10)。

测试程序效果如下:

 

以下代码包括相减函数,比较被减数减数函数,若有错误,请指出:

[cpp] view plain copy print ?
  1. #include "stdio.h"   
  2. #include "string.h"   
  3.   
  4. /************************************************************************/  
  5. /* 高精度减法    (这个函数要a[]>=b[])                                   */  
  6. /* a[]被减数数组,位数不限                                              */  
  7. /* b[]减数数组,位数不限                                                */  
  8. /* back[]结果数组,位数不会大于a[]数组的                                */  
  9. /************************************************************************/  
  10. void sub(char a[],char b[],char back[])  
  11. {  
  12.     int i,k,l1,l2;  
  13.     l1=strlen(a);  
  14.     l2=strlen(b);  
  15.     back[l1]='/0';  
  16.     for (i=l2-1,l1--;i>=0;l1--,i--)                //减数的个数小于等于被减数,所以减的次数依减数而定   
  17.     {  
  18.         if (a[l1]-b[i]>=0)                         //不需要借位相减   
  19.         {  
  20.             back[l1]=a[l1]-b[i]+'0';  
  21.         }  
  22.         else                                       //向前一位借1   
  23.         {  
  24.             back[l1]=10+a[l1]-b[i]+'0';  
  25.             if (a[l1-1]!='0')                      //当前一位非0,可以被借时,直接借来   
  26.             {  
  27.                 a[l1-1]-=1;  
  28.             }  
  29.             else                                   //若前一位为0,则无法借到,继续向前一位的前一位借,循环   
  30.             {  
  31.                 k=l1-1;  
  32.                 while (a[k]=='0')  
  33.                 {  
  34.                     a[k]='9';                      //前一位的0,就变成了10,扣去被后一位借去的,还有9   
  35.                     k--;  
  36.                 }  
  37.                 a[k]-=1;                           //到达可以借的位置   
  38.             }  
  39.         }  
  40.     }  
  41.     while (l1>=0)                                  //被减数多于减数的位数直接赋给结果数组   
  42.     {  
  43.         back[l1]=a[l1];  
  44.         l1--;  
  45.     }  
  46.     while (back[0]=='0')                           //将结果数组往前移,方便以后的操作   
  47.     {  
  48.         l1=strlen(a);  
  49.         for (i=0;i<l1-1;i++)  
  50.         {  
  51.             back[i]=back[i+1];  
  52.         }  
  53.         back[l1-1]='/0';  
  54.     }  
  55.     if (strlen(back)==0)                            //被减数与减数刚好相减为0的情况   
  56.     {  
  57.         back[0]='0';  
  58.         back[1]='/0';  
  59.     }  
  60. }  
  61.   
  62. /************************************************************************/  
  63. /* 判断函数(被减数与减数的大小比较)                                   */  
  64. /* 可以用strcmp函数比较字符串                                           */  
  65. /* 比较完后,若小于减数,则置换带入高精度减法函数,最后加'-'输出        */  
  66. /************************************************************************/  
  67. bool isBigger(char a[],char b[])  
  68. {  
  69.     int l1,l2;  
  70.     l1=strlen(a);  
  71.     l2=strlen(b);  
  72.     if (l1>l2)  
  73.     {  
  74.         return true;  
  75.     }  
  76.     else if (l1<l2)  
  77.     {  
  78.         return false;  
  79.     }  
  80.     else  
  81.     {  
  82.         if (strcmp(a,b)>=0)  
  83.         {  
  84.             return true;  
  85.         }  
  86.         else  
  87.         {  
  88.             return false;  
  89.         }  
  90.     }  
  91. }  
  92.   
  93. /************************************************************************/  
  94. /* 主函数调用                                                           */  
  95. /************************************************************************/  
  96. int main()  
  97. {  
  98.     int n;  
  99.     char a[1000],b[1000],c[1000];  
  100.     printf("%s","计算次数: ");  
  101.     scanf("%d",&n);  
  102.     while (n--)  
  103.     {  
  104.         memset(a,'/0',sizeof(a));  
  105.         memset(b,'/0',sizeof(b));  
  106.         memset(c,'/0',sizeof(c));  
  107.         printf("%s","被减数:  ");  
  108.         scanf("%s",&a);  
  109.         printf("%s","减数:    ");  
  110.         scanf("%s",&b);  
  111.         if (isBigger(a,b))  
  112.         {  
  113.             sub(a,b,c);  
  114.             printf("%s%s/n/n","结果为:  ",c);  
  115.         }  
  116.         else  
  117.         {  
  118.             sub(b,a,c);  
  119.             printf("%s%c%s/n/n","结果为:  ",'-',c);  
  120.         }         
  121.     }  
  122.     return 0;  
  123. }  

这篇关于高精度计算----减法运算的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

uva 575 Skew Binary(位运算)

求第一个以(2^(k+1)-1)为进制的数。 数据不大,可以直接搞。 代码: #include <stdio.h>#include <string.h>const int maxn = 100 + 5;int main(){char num[maxn];while (scanf("%s", num) == 1){if (num[0] == '0')break;int len =

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 1342 欧拉定理(计算几何模板)

题意: 给几个点,把这几个点用直线连起来,求这些直线把平面分成了几个。 解析: 欧拉定理: 顶点数 + 面数 - 边数= 2。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#inc

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

XTU 1237 计算几何

题面: Magic Triangle Problem Description: Huangriq is a respectful acmer in ACM team of XTU because he brought the best place in regional contest in history of XTU. Huangriq works in a big compa

音视频入门基础:WAV专题(10)——FFmpeg源码中计算WAV音频文件每个packet的pts、dts的实现

一、引言 从文章《音视频入门基础:WAV专题(6)——通过FFprobe显示WAV音频文件每个数据包的信息》中我们可以知道,通过FFprobe命令可以打印WAV音频文件每个packet(也称为数据包或多媒体包)的信息,这些信息包含该packet的pts、dts: 打印出来的“pts”实际是AVPacket结构体中的成员变量pts,是以AVStream->time_base为单位的显

计算数组的斜率,偏移,R2

模拟Excel中的R2的计算。         public bool fnCheckRear_R2(List<double[]> lRear, int iMinRear, int iMaxRear, ref double dR2)         {             bool bResult = true;             int n = 0;             dou