算法提高 P1001
必须感叹下,大数模板就是好用!
AC代码:
#include <cstdio> #include <cmath> #include <algorithm> #include <cstring> #include <utility> #include <string> #include <iostream> #include <map> #include <set> #include <vector> #include <queue> #include <stack> using namespace std; #define eps 1e-10 #define inf 0x3f3f3f3f #define PI pair<int, int> typedef long long LL; const int maxn = 1e4 + 5; struct BigInteger { vector<int>s; //12345--54321 void DealZero() { //处理前导0 for(int i = s.size() - 1; i > 0; --i){ if(s[i] == 0) s.pop_back(); else break; } } BigInteger operator = (long long num) { // 赋值运算符 s.clear(); vector<int>tmp; do{ s.push_back(num % 10); num /= 10; }while(num); return *this; } BigInteger operator = (const string& str) { // 赋值运算符 s.clear(); for(int i = str.size() - 1; i >= 0; --i) s.push_back(str[i] - '0'); this->DealZero(); return *this; } BigInteger operator + (const BigInteger& b) const { BigInteger c; c.s.clear(); int len1 = s.size(), len2 = b.s.size(); for(int i = 0, g = 0; g > 0 || i < len1 || i < len2; ++i) { int x = g; if(i < len1) x += s[i]; if(i < len2) x += b.s[i]; c.s.push_back(x % 10); g = x / 10; } return c; } //大数减小数 BigInteger operator - (const BigInteger& b) const { BigInteger c; c.s.clear(); int len1 = s.size(), len2 = b.s.size(); for(int i = 0, g = 0; i < len1 || i < len2; ++i) { int x = g; if(i < len1) x += s[i]; g = 0; if(i < len2) x -= b.s[i]; if(x < 0) { g = -1; //借位 x += 10; } c.s.push_back(x); } c.DealZero(); return c; } BigInteger operator * (const BigInteger& b) const { BigInteger c, tmp; c.s.clear(); int len1 = s.size(), len2 = b.s.size(); for(int i = 0; i < len1; ++i) { tmp.s.clear();tmp; int num = i; while(num--) tmp.s.push_back(0); int g = 0; for(int j = 0; j < len2; ++j) { int x = s[i] * b.s[j] + g; tmp.s.push_back(x % 10); g = x / 10; } if(g > 0) tmp.s.push_back(g); c = c + tmp; } c.DealZero(); return c; } //单精度除法 BigInteger operator / (const int b) const { BigInteger c, tmp; c.s.clear(); int len = s.size(); int div = 0; for(int i = len - 1; i >= 0; --i) { div = div * 10 + s[i]; while(div < b && i > 0) { div = div * 10 + s[--i]; } tmp.s.push_back(div / b); div %= b; } for(int i = tmp.s.size() - 1; i >= 0; --i) c.s.push_back(tmp.s[i]); c.DealZero(); return c; } bool operator < (const BigInteger& b) const { int len1 = s.size(), len2 = b.s.size(); if(len1 != len2) return len1 < len2; for(int i = len1 - 1; i >= 0; --i) { if(s[i] != b.s[i]) return s[i] < b.s[i]; } return false; //相等 } bool operator <= (const BigInteger& b) const { return !(b < *this); } string ToStr() { string ans; ans.clear(); for(int i = s.size()-1; i >= 0; --i) ans.push_back(s[i] + '0'); return ans; } //大数开方 /**大数开方用法说明: 字符串必须从第二个位置开始输入,且s[0] = '0' scanf("%s", s+1); */ BigInteger SQRT(char *s) { string p = ""; s[0]='0'; if(strlen(s)%2 == 1) work(p, 2, s+1, 0); else work(p, 2, s, 0); BigInteger c; c.s.clear(); c = p; return c; } //开方准备 //------------------------------------ int l; int work(string &p, int o,char *O,int I){ char c, *D=O ; if(o>0) { for(l=0;D[l];D[l++]-=10) { D[l++]-=120; D[l]-=110; while(!work(p, 0, O, l)) D[l]+=20; p += (char)((D[l]+1032)/20); } } else { c=o+(D[I]+82)%10-(I>l/2)*(D[I-l+I]+72)/10-9; D[I]+=I<0 ? 0 : !(o=work(p, c/10,O,I-1))*((c+999)%10-(D[I]+92)%10); } return o; } //----------------------------------------- }; ostream& operator << (ostream &out, const BigInteger& x) { for(int i = x.s.size() - 1; i >= 0; --i) out << x.s[i]; return out; } istream& operator >> (istream &in, BigInteger& x) { string s; if(!(in >> s)) return in; x = s; return in; } int main() { BigInteger a, b; while(cin >> a >> b) { cout << a * b << "\n"; } return 0; }
如有不当之处欢迎指出!
算法提高 P1001的更多相关文章
- 蓝桥杯算法提高 P1001(大数乘法)
算法提高 P1001 时间限制:1.0s 内存限制:256.0MB 当两个比较大的整数相乘时,可能会出现数据溢出的情形.为避免溢出,可以采用字符串的方法来实现两个大数之间的乘法. 具体 ...
- Java实现 蓝桥杯 算法提高 p1001
算法提高 P1001 时间限制:1.0s 内存限制:256.0MB 提交此题 当两个比较大的整数相乘时,可能会出现数据溢出的情形.为避免溢出,可以采用字符串的方法来实现两个大数之间的乘法.具体来说 ...
- 算法提高 P1001【大数乘法】
当两个比较大的整数相乘时,可能会出现数据溢出的情形.为避免溢出,可以采用字符串的方法来实现两个大数之间的乘法.具体来说,首先以字符串的形式输入两个整数,每个整数的长度不会超过8位,然后把它们相乘的结果 ...
- 算法笔记_097:蓝桥杯练习 算法提高 P1001(Java)
目录 1 问题描述 2 解决方案 1 问题描述 当两个比较大的整数相乘时,可能会出现数据溢出的情形.为避免溢出,可以采用字符串的方法来实现两个大数之间的乘法.具体来说,首先以字符串的形式输入两个整 ...
- 机器学习实战 - 读书笔记(07) - 利用AdaBoost元算法提高分类性能
前言 最近在看Peter Harrington写的"机器学习实战",这是我的学习笔记,这次是第7章 - 利用AdaBoost元算法提高分类性能. 核心思想 在使用某个特定的算法是, ...
- 算法提高 c++_ch02_01
http://lx.lanqiao.org/problem.page?gpid=T237 算法提高 c++_ch02_01 时间限制:1.0s 内存限制:512.0MB 编写一个程 ...
- 算法提高 9-3摩尔斯电码 map
算法提高 9-3摩尔斯电码 时间限制:1.0s 内存限制:256.0MB 问题描述 摩尔斯电码破译.类似于乔林教材第213页的例6.5,要求输入摩尔斯码,返回英文.请不要使用"z ...
- 算法提高 金属采集_树形dp
算法提高 金属采集 时间限制:1.0s 内存限制:256.0MB 问题描述 人类在火星上发现了一种新的金属!这些金属分布在一些奇怪的地方,不妨叫它节点好了.一些节点之间有道路相连 ...
- 算法提高 最小方差生成树(Kruskal)_模板
算法提高 最小方差生成树 时间限制:1.0s 内存限制:256.0MB 问题描述 给定带权无向图,求出一颗方差最小的生成树. 输入格式 输入多组测试数据.第一行为N,M,依次是 ...
随机推荐
- Maven初步
Maven初入 maven 是一个项目管理工具, 它包含了一个 项目对象模型(Project Object Model POM), 一组标准集合, 一个项目生命周期(Project Lifecycle ...
- shell中awk printf的用法
打印输出时,可能需要指定字段间的空格数,从而把列排整齐.在print函数中使用制表符并不能保证得到想要的输出,因此,可以用printf函数来格式化特别的输出. printf函数返回一个带格式的字符串给 ...
- 监控 Linux 性能的 18 个命令行工具[转]
对于系统和网络管理员来说每天监控和调试Linux系统的性能问题是一项繁重的工作.在IT领域作为一名Linux系统的管理员工作5年后,我逐渐认识到监控和保持系统启动并运行是多么的不容易.基于此原因,我们 ...
- openstack一键安装脚本(转载)
#!/bin/sh # openstack pike 单机 一键安装 # 环境 centos 7.4.1708 x86_64 # 更多内容 http://dwz.cn/openstack # Myde ...
- ATS日志说明
在ATS日志中我们经常遇到形形色色的缓存结果码,为了更清晰地认识它们,相关资料整理到这里: TCP_HIT 请求对象的一份合法拷贝被缓存,ATS将发送该对象给client TCP_MISS 请求对象未 ...
- 聊聊js里面容易忽视的一些东西(1)
JavaScript对象的创建方式 在JavaScript中,创建对象的方式包括两种:对象字面量和使用new表达式.对象字面量是一种灵活方便的书写方式,例如: 1 2 3 4 5 6 var o1 ...
- Python selenium 一个节点两个关联input
HTML代码: 一个节点两个关联input 多出现于密码框 先需要模拟点击进入第一个input,才能激活第二个input. 代码: driver.find_element_by_name('Text ...
- 使用H2数据库进行单元测试
背景 H2 数据库是一个开源的嵌入型内存数据库,采用纯Java语言实现: 程序非常小巧轻便,整个完整的Jar包也只有1.5M左右,很容易集成到项目中. 官网地址 http://www.h2databa ...
- OpenStack和Hadoop的区别
其实,OpenStack和Hadoop不是同一个层次的东西,无法比较,非要说出个区别,那就是:OpenStack是云计算管理平台,应该是属于系统级别的软件,它的主体思想是把资源进行分离,给不同的用户提 ...
- SpringMVC源码情操陶冶-AbstractUrlHandlerMapping
承接前文SpringMVC源码情操陶冶-AbstractHandlerMapping,前文主要讲解了如何获取handler处理对象,本文将针对beanName注册为handler对象作下解析 Abst ...