c++各类大数模板

首先大数加法 两个大数相加

string sum(string s1,string s2)
{
	if(s1.length()<s2.length())
	{
		string temp=s1;
		s1=s2;
		s2=temp;
	}
	int i,j;
	for(i=s1.length()-1,j=s2.length()-1;i>=0;i--,j--)
	{
		s1[i]=char(s1[i]+(j>=0?s2[j]-‘0‘:0));   //注意细节
		if(s1[i]-‘0‘>=10)
		{
			s1[i]=char((s1[i]-‘0‘)%10+‘0‘);
			if(i) s1[i-1]++;
			else s1=‘1‘+s1;
		}
	}
	return s1;
}

博客链接:

http://blog.csdn.net/y990041769/article/details/19545179


然后大数乘以整形数

string Multiply(string s,int x)  //大数乘以整形数
{
    reverse(s.begin(),s.end());
    int cmp=0;
    for(int i=0;i<s.size();i++)
    {
        cmp=(s[i]-‘0‘)*x+cmp;
        s[i]=(cmp%10+‘0‘);
        cmp/=10;
    }
    while(cmp)
    {
        s+=(cmp%10+‘0‘);
        cmp/=10;
    }
    reverse(s.begin(),s.end());
    return s;
}

博客链接:http://blog.csdn.net/y990041769/article/details/12645953


大数除以整形数

string Except(string s,int x)  //大数除以整形数
{
    int cmp=0,ok=0;
    string ans="";
    for(int i=0;i<s.size();i++)
    {
        cmp=(cmp*10+s[i]-‘0‘);
        if(cmp>=x)
        {
            ok=1;
            ans+=(cmp/x+‘0‘);
            cmp%=x;
        }
        else{
            if(ok==1)
                ans+=‘0‘;  //注意这里啊。才找出错误
        }
    }
    return ans;
}

博客链接:http://blog.csdn.net/y990041769/article/details/9262943


字符串去除后导0函数,前导0可以先反转取后导。

string Remove_later(string s)   //删除一个字符串的后倒0
{
    for(int i=s.size()-1; i>=0; i--)
    {
        if(s[i]==‘0‘)
            s.erase(i);
        else
            break;
    }
    return s;
}

题目:http://acm.nyist.net/JudgeOnline/problem.php?pid=272


其他的正在完善中。争取写出自己的模板。

c++各类大数模板,布布扣,bubuko.com

c++各类大数模板

上一篇:C语言--单链表创建、求长度、查找前驱结点、删除结点


下一篇:C++关键字:mutable、volatile、explicit以及__based(转载)