首页 > 其他分享 >高精度板子

高精度板子

时间:2022-11-25 18:46:04浏览次数:35  
标签:string 高精度 int str2 str1 cf 板子 str

 

#include <bits/stdc++.h>
using namespace std;

int compare(string str1,string str2){
    if(str1.length()>str2.length()) return 1;
    else if(str1.length()<str2.length())  return -1;
    else return str1.compare(str2);
}
  string sub(string str1,string str2){
    string str;
    int tmp=str1.length()-str2.length();
    int cf=0;
    for(int i=str2.length()-1;i>=0;i--){
        if(str1[tmp+i]<str2[i]+cf){
            str=char(str1[tmp+i]-str2[i]-cf+'0'+10)+str;
            cf=1;
        }
        else{
            str=char(str1[tmp+i]-str2[i]-cf+'0')+str;
            cf=0;
        }
    }
    for(int i=tmp-1;i>=0;i--){
        if(str1[i]-cf>='0'){
            str=char(str1[i]-cf)+str;
            cf=0;
        }
        else{
            str=char(str1[i]-cf+10)+str;
            cf=1;
        }
    }
    str.erase(0,str.find_first_not_of('0'));
    return str;
}
string add(string str1,string str2){
    string str;
    int len1=str1.length();
    int len2=str2.length();
    
    if(len1<len2){
        for(int i=1;i<=len2-len1;i++)
           str1="0"+str1;
    }
    else{
        for(int i=1;i<=len1-len2;i++)
           str2="0"+str2;
    }
    len1=str1.length();
    int cf=0;
    int temp;
    for(int i=len1-1;i>=0;i--){
        temp=str1[i]-'0'+str2[i]-'0'+cf;
        cf=temp/10;
        temp%=10;
        str=char(temp+'0')+str;
    }
    if(cf!=0)  str=char(cf+'0')+str;
    return str;
}
string mul(string str1,string str2){
    string str;
    int len1=str1.length();
    int len2=str2.length();
    string tempstr;
    for(int i=len2-1;i>=0;i--){
        tempstr="";
        int temp=str2[i]-'0';
        int t=0;
        int cf=0;
        if(temp!=0){
            for(int j=1;j<=len2-1-i;j++)
              tempstr+="0";
            for(int j=len1-1;j>=0;j--){
                t=(temp*(str1[j]-'0')+cf)%10;
                cf=(temp*(str1[j]-'0')+cf)/10;
                tempstr=char(t+'0')+tempstr;
            }
            if(cf!=0) tempstr=char(cf+'0')+tempstr;
        }
        str=add(str,tempstr);
    }
    str.erase(0,str.find_first_not_of('0'));
    return str;
} 
 // a/b  str1->a ,str2->b 
void div(string str1,string str2,string &quotient,string &residue){
    quotient=residue="";
    if(str2=="0"){
        quotient=residue="ERROR";
        return;
    }
    if(str1=="0"){
        quotient=residue="0";
        return;
    }
    int res=compare(str1,str2);
    if(res<0){
        quotient="0";
        residue=str1;
        return;
    }
    else if(res==0){
        quotient="1";
        residue="0";
        return;
    }
    else{
        int len1=str1.length();
        int len2=str2.length();
        string tempstr;
        tempstr.append(str1,0,len2-1);
        for(int i=len2-1;i<len1;i++){
            tempstr=tempstr+str1[i];
            tempstr.erase(0,tempstr.find_first_not_of('0'));
            if(tempstr.empty())
              tempstr="0";
            for(char ch='9';ch>='0';ch--){
                string str,tmp;
                str=str+ch;
                tmp=mul(str2,str);
                if(compare(tmp,tempstr)<=0){
                    quotient=quotient+ch;
                    tempstr=sub(tempstr,tmp);
                    break;
                }
            }
        }
        residue=tempstr;
    }
    quotient.erase(0,quotient.find_first_not_of('0'));
    if(quotient.empty()) quotient="0";
}
 
 
 

 

标签:string,高精度,int,str2,str1,cf,板子,str
From: https://www.cnblogs.com/towboa/p/16926038.html

相关文章

  • 一些板子
    离散化://离散化,可以处理一些跨越区间比较大的时候的位置关系,空间更紧凑intn,m;inta[N],b[N],c[N];intcnt=0;//lower_bound第一个大于等于x的数//upper_bound......
  • CSP-J/S & NOIP 常用板子大全 !
    HNCSP-J/S2022RP++!序号算法①SPFA②并查集③最小生成树④拓扑排序⑤堆⑥字典树N懒得加了1.SPFA题目链接题目描述输入......
  • 快速幂(板子)
    先讨论无需取模的当b为偶数时:ab=a(b/2)*2=(a2)b/2当b为奇数时:ab=a*ab-1=a*(a2)(b-1)/2如 28=(22)4     27=2*(22)3所以,我们可以如此迭代下......
  • [AcWing 792]高精度减法
    点击查看代码#include<iostream>#include<vector>usingnamespacestd;//判断A>=B返回trueA<B返回falseboolcmp(vector<int>A,vector<int>B){//当A的......
  • 压位高精度模板
    压位高精全家桶。原代码来自于知乎上人形魔芋的压位高精模板,进行了一些修改和改进。namespaceBigInteger{typedeflonglongll;typedefunsignedlonglong......
  • 一个很好用的 C++ 高精度整数板子
    点击查看代码typedeflonglongll;typedeflongdoubleld;typedefcomplex<ld>pt;constintMOD=1e9+7;constldPI=acos(-1.L);template<classT>struc......
  • 信息学集训 | 17 高精度算法理论与实现2
    戳一戳!和我一起走进信息学的世界导读信息学能够有助于孩子未来工作发展,提升孩子的综合能力。这一节课是我们这一期课程的最后一节课,我们继续学习高精度算法,回顾如何高精度算......
  • 高精度AxB
    洛谷1303#include<iostream>usingnamespacestd;constintN=50000;intarr[2*N];intaa[N];intbb[N];intmain(){stringa,b;cin>>a>>b;for(in......
  • 高精度A+B
    A+B`考虑高精度代码#include<iostream>usingnamespacestd;constintN=510;intarr[N],aa[N],ab[N];intmain(){stringa,b;cin>>a;cin>>b;......
  • 《STM32MP1 M4裸机HAL库开发指南》第二十一章 Systick高精度延时实验
    第二十一章Systick高精度延时实验前面章节的实验我们使用的是HAL库里自带的API函数HAL_Delay来实现毫秒级别延时的,如果使用到更高精度的延时,例如us级别的延时,我们可以使用......