亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? bignumber.cpp

?? 二分法求大整數(shù)相乘
?? CPP
字號:
#include "BigNumber.h"
#include <iostream.h>
#include <algorithm>

BigNumber::BigNumber(int max)
{
	nMaxLen = max;
	pNum = new char[max];
	nLength = 0;
}

BigNumber::BigNumber(const BigNumber& bn)
{
	nMaxLen = bn.nMaxLen;
	pNum = new char[nMaxLen];
	nLength = bn.nLength;

	int i = 0;
	while(i < nLength)
	{
		pNum[i] = bn.pNum[i];
		++i;
	}
}

BigNumber BigNumber::operator= (const BigNumber& bn)
{
	if(nMaxLen != bn.nMaxLen)
	{
		delete []pNum;
		nMaxLen = bn.nMaxLen;
		pNum = new char[nMaxLen];
	}
	nLength = bn.nLength;

	int i = 0;
	while(i < nLength)
	{
		pNum[i] = bn.pNum[i];
		++i;
	}

	return *this;
}

BigNumber BigNumber::operator<<(int n)
{
	BigNumber bn(nMaxLen);
	int i = 0;
	while(i < n)
	{
		bn.pNum[i] = '0';
		++i;
	}

	int j = 0;
	while(j < nLength)
	{
		bn.pNum[i] = pNum[j];
		++j;
		++i;
	}
	bn.nLength = nLength + n;
	return bn;
}

BigNumber BigNumber::operator>>(int n)
{
	BigNumber bn(nMaxLen);
	if(n > nLength)
	{	
		bn.nLength = 1;
		bn.pNum[0] = '0';
	}
	else
	{
		bn.nLength = nLength - n;
		int i,j;
		i = n,j = 0;
		while(i < nLength)
		{
			bn.pNum[j] = pNum[i];
			++i;
			++j;
		}
	}

	return bn;
}

char BigNumber::operator[](int n) const
{
	if(n >= nLength)
		return '0';
	else
		return pNum[n];
}

BigNumber BigNumber::operator+(const BigNumber& bn)
{
	BigNumber res(nMaxLen);
	int len = bn.nLength > nLength ? bn.nLength : nLength;
	int i,tmp,carry;
	carry = 0;
	for(i = 0;i < len;++i)
	{
		tmp = int((*this)[i] - '0' + bn[i] - '0') + carry;
		if(tmp >= 10)
		{
			tmp %= 10;
			carry = 1;
		}
		else
			carry = 0;
		res.pNum[res.nLength++] = char(tmp + '0');
	}
	if(carry == 1)
		res.pNum[res.nLength++] = '1';

	return res;
}

BigNumber BigNumber::operator-(const BigNumber& bn)
{
	BigNumber res(bn.nMaxLen);
	int len = (nLength > bn.nLength ? nLength : bn.nLength);
	
	int i,tmp,carry;
	carry = 0;
	for(i = 0;i < len;++i)
	{
		tmp = int((*this)[i] - bn[i] - carry);
		if(tmp < 0)
		{
			tmp += 10;
			carry = 1;
		}
		else
			carry = 0;
		res.pNum[res.nLength++] = char(tmp + '0');
	}
	if(res.IsZero())
		res.nLength = 1;
	else 
		res.RemoveZero();
	return res;
}

BigNumber BigNumber::operator*(BigNumber bn)
{
	BigNumber res(2*nMaxLen);
	int len = (nLength > bn.nLength ? nLength : bn.nLength);
	int rlen = 1;
	while(rlen < len)
		rlen <<= 1;
	len = rlen;

	if(len == 1)
	{
		if(IsZero()|| bn.IsZero())
		{
			res.pNum[0] = '0';
			res.nLength = 1;
		}
		else
		{
			int tmp = (pNum[0] - '0')*(bn[0] - '0');
			int low = tmp % 10;
			int high = tmp / 10;
			if(high != 0)
			{
				res.pNum[0] = char(low + '0');
				res.pNum[1] = char(high + '0');
				res.nLength = 2;
			}
			else
			{
				res.pNum[0] = char(low + '0');
				res.nLength = 1;
			}
		}
	}
	else
	{
		BigNumber a1 = (*this)>>(len>>1);
		BigNumber b1 = (*this) - (a1<<(len>>1));
		BigNumber a2 = bn>>(len>>1);
		BigNumber b2 = bn - (a2<<(len>>1));

		BigNumber a1a2 = a1 * a2;
		BigNumber b1b2 = b1 * b2;
		BigNumber abcd = (a1 + b1)*(a2 + b2) - a1a2 - b1b2;
		
		res = (a1a2<<len) + (((a1 + b1)*(a2 + b2) - a1a2 - b1b2)<<(len>>1)) + b1b2;
	}
	return res;
}
bool BigNumber::IsZero()
{
	int i = 0;
	while(i < nLength)
	{
		if(pNum[i] != '0')
			return false;
		++i;
	}
	return true;
}

void BigNumber::RemoveZero()
{
	while(pNum[nLength - 1] == '0')
			--nLength;
}

ostream& operator<< (ostream& out,BigNumber& bn)
{
	if(bn.IsZero())
	{
		bn.pNum[0] = '0';
		bn.nLength = 1;
	}
	else
		bn.RemoveZero();
	bn.pNum[bn.nLength] = '\0';
	std::reverse(bn.pNum,bn.pNum + bn.nLength);
	out << bn.pNum;
	std::reverse(bn.pNum,bn.pNum + bn.nLength);
	return out;
}

istream& operator>> (istream& in,BigNumber& bn)
{
	in >> bn.pNum;
	bn.nLength = strlen(bn.pNum);
	std::reverse(bn.pNum,bn.pNum + bn.nLength);
	return in;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久永久免费观看 | 3d成人h动漫网站入口| 日韩视频在线永久播放| 国产精品一级在线| 在线观看一区日韩| 亚洲三级免费电影| 中文字幕欧美区| 日韩毛片高清在线播放| 亚洲美女屁股眼交| 亚洲一区二区三区视频在线播放| 亚洲图片激情小说| 一区二区三区美女视频| 日韩精品每日更新| 狠狠色综合播放一区二区| 色欧美片视频在线观看| 欧美精品一区二| 一区二区三区不卡视频在线观看 | 欧美色图在线观看| 日韩一卡二卡三卡国产欧美| 国产午夜精品福利| 久久99精品久久久久久国产越南| 欧美男同性恋视频网站| 欧美日韩一级视频| 国产日产精品一区| 免费一级欧美片在线观看| 99在线视频精品| 国产精品污www在线观看| 成人综合在线观看| 亚洲欧美激情一区二区| 欧美日韩精品是欧美日韩精品| 色综合久久久久综合| 国产亚洲欧美中文| 日本欧洲一区二区| 欧美亚洲日本一区| 18欧美亚洲精品| 国产成人精品三级麻豆| 欧美一区二区福利在线| 亚洲美女在线国产| 99在线视频精品| 亚洲人精品一区| 麻豆精品在线播放| 3d成人动漫网站| 偷拍亚洲欧洲综合| 4438成人网| 国产麻豆欧美日韩一区| 日韩亚洲国产中文字幕欧美| 午夜成人在线视频| 日韩亚洲欧美高清| 极品少妇一区二区| 久久久精品免费网站| 国产一区啦啦啦在线观看| 久久中文娱乐网| 国产精品亚洲一区二区三区在线| 久久蜜桃香蕉精品一区二区三区| 国产一区二区三区在线观看免费| 26uuu另类欧美亚洲曰本| 国产中文字幕一区| 国产精品乱人伦一区二区| 91老司机福利 在线| 一区二区三区在线视频免费观看| 色哟哟国产精品免费观看| 午夜精品爽啪视频| 精品999在线播放| 国产精品一区免费在线观看| 久久精品亚洲精品国产欧美| 99国产精品国产精品久久| 亚洲综合久久av| 精品福利av导航| 成人av免费观看| 五月天欧美精品| 波多野结衣欧美| 一级特黄大欧美久久久| 日韩精品一区二区三区视频在线观看| 韩日精品视频一区| 一区二区三区中文在线| 久久人人超碰精品| 欧美欧美欧美欧美| 99久久婷婷国产综合精品| 天天综合网 天天综合色| 国产精品女主播av| 精品国产91乱码一区二区三区| 色综合婷婷久久| 高清国产午夜精品久久久久久| 午夜视频久久久久久| 国产精品传媒入口麻豆| 欧美一级免费大片| 欧美系列一区二区| 成人免费视频播放| 国产精品1区二区.| 日本aⅴ精品一区二区三区| 中文字幕亚洲精品在线观看| 精品国产在天天线2019| 欧美一区二区三区视频免费播放| 色av一区二区| 色婷婷亚洲婷婷| 欧美不卡123| 精品久久国产97色综合| 777精品伊人久久久久大香线蕉| 欧美在线999| 欧美影院精品一区| 欧美日韩国产系列| 欧美视频完全免费看| 欧美视频一区二区| 日韩亚洲欧美在线| 久久精品欧美一区二区三区不卡 | 亚洲精品欧美在线| 亚洲国产精品欧美一二99| 亚洲成人一二三| 国产亚洲自拍一区| 国产亚洲成年网址在线观看| 久久先锋资源网| 欧美激情在线观看视频免费| 中文字幕av资源一区| 一区二区三区波多野结衣在线观看| 一区二区成人在线| 玖玖九九国产精品| 成人白浆超碰人人人人| 日本道色综合久久| 日韩视频一区二区| 国产精品另类一区| 午夜视频一区二区| 国产一区二区看久久| 色综合视频一区二区三区高清| 在线观看国产91| 久久精品在线观看| 亚洲午夜免费视频| 盗摄精品av一区二区三区| 欧美性做爰猛烈叫床潮| 久久久久国产一区二区三区四区| 国产欧美日本一区二区三区| 亚洲大片免费看| 97se亚洲国产综合在线| 一区二区三区蜜桃网| 国产专区欧美精品| 欧美精品久久99| 亚洲精品国产一区二区精华液 | 欧美美女视频在线观看| 欧美成人精品1314www| 亚洲精品国产成人久久av盗摄| 国内精品国产三级国产a久久| 91在线国产福利| 国产婷婷色一区二区三区在线| 欧美三级在线播放| 国产精品国产三级国产三级人妇| 日韩经典中文字幕一区| 色综合久久综合网97色综合| 久久久久久久久久久久电影| 日本不卡一区二区三区高清视频| 国产精品69毛片高清亚洲| 欧美色网一区二区| 一区二区三区欧美日韩| aaa欧美日韩| 国产精品私房写真福利视频| 国产精品一区二区无线| 欧美成人a视频| 国内国产精品久久| 久久午夜色播影院免费高清| 久久精品久久综合| 久久精品男人天堂av| 国产v综合v亚洲欧| 国产精品久久久久久久久果冻传媒| 国产精品99久久久久久宅男| 国产日韩欧美激情| 99精品视频一区二区| 亚洲一区影音先锋| 欧美精品一二三| 久99久精品视频免费观看| 欧美精品一区二区久久久| 粉嫩一区二区三区在线看| 国产精品成人在线观看| 欧美视频精品在线| 久久综合综合久久综合| 中文字幕一区二区三区蜜月| 一本高清dvd不卡在线观看| 亚洲国产精品一区二区www在线 | 日本亚洲免费观看| 2020日本不卡一区二区视频| 99久久精品国产一区| 天天影视网天天综合色在线播放 | 99这里只有精品| 日本va欧美va瓶| 亚洲三级电影全部在线观看高清| 欧美日韩精品欧美日韩精品| 国产精品中文字幕日韩精品| 亚洲午夜精品网| 久久精品欧美日韩| 日韩亚洲欧美综合| 在线视频一区二区免费| 粉嫩一区二区三区性色av| 三级久久三级久久久| 亚洲色大成网站www久久九九| 337p日本欧洲亚洲大胆色噜噜| 一本在线高清不卡dvd| 国产伦精品一区二区三区视频青涩| 亚洲国产欧美在线人成| 中文字幕亚洲区| 色婷婷av一区| a级精品国产片在线观看| 国产一区二区精品久久91| 日韩精品一二三|