很久以前写的啦
记得写了好久好久一直卡在特例的数据上面
想起都心塞

那时候变量和数组的取名对我来说简直是个大难题啊
完全乱来 abcdef就一路排下来
自己看的时候都搞不懂分别代表什么
好在后来英语学的越来越好了
这也算是学c++的附带好处叭
而且格式也写得非常丑…
我翻出来的时候各种字符都挨在一起密密麻麻…
真是搞不懂那时候怎么想的
稍微补了下空格但其它地方就懒得改啦
见谅

不过我当时居然写了注释…
太神奇了
^^

其实只要自己手动模拟一下小学的竖式乘加减和除法
思考一下 下标关系 和 进位处理 就会发现还是很简单的啦
坑的地方我现在还依稀记得两个
一个是减法 被减数比减数小的情况要特判加负号
一个是前缀零的处理 但是要特判答案为0的情况

还有做除法的时候 被除数比除数小或者除数为0的时候可以直接输0 节约时间

不过我除法做的方法不太常规…虽然说我也不知道常规应该咋写^^

加法

#include<bits/stdc++.h>
#include<cstring>
using namespace std; char s1[300] , s2[300] ;
int c[300] , ans , t , a[300] , b[300] ; int main()
{ memset(a , 0 , sizeof(a));
memset(b , 0 , sizeof(b));
memset(c , 0 , sizeof(c));
gets(s1) ;
gets(s2) ;
int len1 = strlen(s1) , len2 = strlen(s2) , len3 = 1 ;
for(int i = 1 ; i <= len1 ; ++ i )
a[i] = s1[len1 - i] - '0' ;
for(int i = 1 ; i <= len2 ; ++ i )
b[i] = s2[len2 - i] - '0' ;
while(len3 <= len1 || len3 <= len2)
{
ans = a[len3] + b[len3] ;
c[len3] = (ans + t) % 10 ;
t = (ans + t) / 10 ;
++ len3 ;
}
if(t != 0)
c[len3] = t ;
while(c[len3] == 0 && len3 > 1) -- len3 ; //删除前导0
for(int i = len3 ; i >= 1 ; -- i )
cout << c[i] ;
return 0;
}

减法

#include<bits/stdc++.h>
using namespace std; char s1[300] , s2[300] , s3[300] ;
int c[300] , ans , t=0 , a[300] , b[300] ; int main()
{
memset(a , 0 , sizeof(a)) ;
memset(b , 0 , sizeof(b)) ;
memset(c , 0 , sizeof(c)) ;
gets(s1) ;
gets(s2) ;
int len1 = strlen(s1) , len2 = strlen(s2) , len3 = 1 , len4 ;
//if(len2>len1||(len2==len1)&&(strcmp(s1,s2)<0))
//strcpy(s3,s1),strcpy(s1,s2),strcpy(s2,s3),cout<<"-",len4=len1,len1=len2,len2=len4; //这里是处理减数比被减数大的情况
for(int i = 1 ; i <= len1 ; ++ i ) a[i] = s1[len1 - i] - '0' ;
for(int i = 1 ; i <= len2 ; ++ i ) b[i] = s2[len2 - i] - '0' ;
while(len3 <= len1 || len3 <= len2)
{
ans = a[len3] - b[len3] - t ;//t是前一个数借的数
t = 0 ;
if(ans < 0) ans += 10 , t = 1 ;
c[len3] = ans ;
++ len3 ;
}
while(c[len3] == 0 && len3 > 1) -- len3 ; //前导0
for(int i = len3 ; i >= 1 ; -- i )
cout << c[i];
return 0;
}

乘法

#include<bits/stdc++.h>
#include<cstring>
using namespace std; char s1[500] , s2[500] ;
int c[500] , ans , t , a[500] , b[500] ; int main()
{ memset(a , 0 , sizeof(a));
memset(b , 0 , sizeof(b));
memset(c , 0 , sizeof(c));
gets(s1);
gets(s2);
int len1 = strlen(s1) , len2 = strlen(s2) ;
for(int i = 1 ; i <= len1 ; ++ i )
a[i] = s1[len1 - i] - '0' ;
for(int i = 1 ; i <= len2 ; ++ i )
b[i] = s2[len2 - i] - '0' ;
for(int i = 1 ; i <= len1 ; ++ i ){
t=0;
for(int j = 1 ; j <= len2 ; ++ j ){
c[i + j - 1] += a[i] * b[j] + t;
t = c[i + j - 1] / 10;
c[i + j - 1] %= 10;
}
c[ i+ len2] = t;
}
int len3 = len1 + len2 ;
while(c[len3] == 0 && len3 > 1) -- len3 ;
for(int i = len3 ; i >= 1 ; -- i)
cout << c[i] ;
return 0;
}

除法(带余)

#include<bits/stdc++.h>
using namespace std; char s1[300] , s2[300] , s3[300];
int c[300] , ans , t=0 , a[300] , b[300] , f[300] , d , e , p; int main()
{
memset(a , 0 , sizeof(a));
memset(b , 0 , sizeof(b));
memset(c , 0 , sizeof(c));
gets(s1) ;
gets(s2) ;
int len1 = strlen(s1) , len2 = strlen(s2) , len3 ;
for(int i = 1 ; i <= len1 ; i++) a[i] = s1[len1 - i] - '0' ;
for(int i = 1 ; i <= len2 ; i++) b[i] = s2[len2 - i] - '0' ;
d = len1 ;
if(len2 > len1 || (len1 == len2) && (strcmp(s1,s2) < 0) )//如果除数比被除数小直接输0;
{
cout << 0 ;
return 0 ;
}
if(len1 == 1 && a[1] == 0)//如果被除数为0直接输0;
{
cout << 0 ;
return 0 ;
}
while(d != 0)
{
memset(f , 0 , sizeof(f)) ;
while(a[d] == 0 && d > 0) -- d ;//d为当前被除部分的左端
if(d < 1) break ;
e = d - len2 + 1 ;
p = 1 ;
for(int j = 1 ; j <= len2 ; ++ j){//把当前被除的部分放到f数组里与除数比较大小
f[j] = a[e+j-1] ;
if(f[j] < b[j]) p = 0 ;
else if(f[j] > b[j]) p = 1 ;//用p来讨论大小
}
if(p == 0) -- e ;//e为当前被除部分的右端
if(e <= 0) break ;//在商加1之前讨论被除数有没有除完
for(int j = 1 ; j <= len2 ; ++ j){
int k = e + j - 1 ;
a[k] -= b[j] ;
if(a[k] < 0) a[k] += 10 , -- a[k+1] ;
}//只减一次 剩下的部分参与下一次循环
++ c[e] ;
}
++ d ;
while(c[len1] == 0 && len1 > 0) -- len1 ;
while(a[d] == 0 && d > 1) -- d ;
for(int i = len1 ; i >= 1 ; -- i)
cout << c[i] ;
//for(int i=d;i>=1;i--)
// cout<<a[i];//这里还可以输出余数
return 0; }

c++ 高精度 加减乘除 四则运算 代码实现的更多相关文章

  1. c++的正整数高精度加减乘除

    数值计算之高精度加减乘除 一.      高精度正整数的高精度计算 1.加法 2.减法 减法和加法的最大区别在于:减法是从高位开始相减,而加法是从低位开始相加 3.乘法:用高精度加法实现 l 乘法的主 ...

  2. Qt之加减乘除四则运算-支持负数

    一.效果展示 如图1所示,是简单的四则运算测试效果,第一列为原始表达式,第二列为转换后的后缀表达式,冒号后为结果.表达式支持负数和空格,图中是使用了5组测试数据,测试结果可能不全,如大家发现算法有问题 ...

  3. poj 1348 Computing (四个数的加减乘除四则运算)

    http://poj.org/problem?id=1348 Computing Time Limit: 1000MS   Memory Limit: 10000K Total Submissions ...

  4. java实现超大整数加减乘除四则运算

    原理: 用数组存储数字,按照计算法则进行运算. 代码: package com.hdwang; import java.util.regex.Matcher; import java.util.reg ...

  5. 用Java位运算实现加减乘除四则运算

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6412875.html 感谢博客:http://blog.csdn.net/itismelzp/article/ ...

  6. C++高精度加减乘除模板

    其中高精度乘法通过了POJ2389,其他没有测过,不过应该是没有问题的. 其中高精度除法返回一对string,分别表示商和余数. 代码: #include <bits/stdc++.h> ...

  7. Python基础算法综合:加减乘除四则运算方法

    #!usr/bin/env python# -*- coding:utf-8 -*-#python的算法加减乘除用符号:+,-,*,/来表示#以下全是python2.x写法,3.x以上请在python ...

  8. c++四则运算代码

    //Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/--& ...

  9. ACM高精度加减乘除模板

    [转]#include <iostream> #include <string> using namespace std; inline int compare(string ...

随机推荐

  1. 喵哈哈村的魔法考试 Round #5 (Div.2) ABCC2

    官方题解:http://www.cnblogs.com/qscqesze/p/6516139.html 喵哈哈村的狼人杀大战(1) 描述 喵哈哈村最近热衷于玩一个叫做狼人杀的游戏! 张小田今天她抽到的 ...

  2. Party Games UVA - 1610

    题目 #include<iostream> #include<string> #include<algorithm> using namespace std; // ...

  3. 看Facebook是如何优化React Native性能

    原文出处: facebook   译文出处:@Siva海浪高 该文章翻译自Facebook官方博客,传送门 React Native 允许我们运用 React 和 Relay 提供的声明式的编程模型, ...

  4. Hadoop调度框架

        大数据协作框架是一个桐城,就是Hadoop2生态系统中几个辅助的Hadoop2.x框架.主要如下: 1,数据转换工具Sqoop 2,文件搜集框架Flume 3,任务调度框架Oozie 4,大数 ...

  5. Web API 实体显示注释

    我看园子里关于Web API的注释都是关于方法的,并没有显示实体注释的方法,今天花了一些时间搞了一下 其实注释的显示就是根据类库的XML文档文件生成的. 首先你要将所用到的类库生成XML文档文件: 在 ...

  6. CF967D Resource Distribution

    思路: 在一堆服务器中,资源最少的那一个是“瓶颈”,由此想到贪心思路. 首先对所有服务器按照资源数量c排序,再从头到尾扫描.对每个位置,根据x1和x2计算出两段连续的服务器集合分别分配给A任务和B任务 ...

  7. java中同步(synchronized)详解

    一.开山篇: 1.synchronized的使用 一个程序中,如果该类中的代码可能运行于多线程环境下,那么就要考虑同步的问题.在Java中内置了语言级的同步原语--synchronized,这也大大简 ...

  8. python+selenium(python基础)

    1.编辑器的选择 好刀不误砍柴工,那么我们写代码也需要一个利器,虽然python自带有python shell ,但我们在执行代码的时候,需要开很多窗口,最重要的一点是,代码文件的管理很不方便,笔者推 ...

  9. Sublime Text插件的离线安装-使用htmlprettify美化您的HTML代码

    Sublime Text是广大程序员喜欢的文本编辑器,Jerry觉得它最强大之处在于开放的架构,有丰富的插件为其提供各种各样额外的功能. 作为前端开发人员,经常需要从网上复制粘贴一些代码然后做修改,因 ...

  10. 什么是python 中的顶层代码?

    在python语言中我们经常会听到顶层代码的说法,但是什么是顶层代码? 在python中,我们是以缩进来区分代码层次的,所以顶层代码指的是缩进为0个空格的代码. 看如下例子: PP = 3.14 de ...