URAL - 1153 Supercomputer 大数开方
题意:给定m,m = n * (n+1) / 2,计算n值。
思路:n = SQRT(m*2)
注意m很大,需要自己实现大数开方。我用的是自己写的大数模板:大数模板
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 char *a) { int n = strlen(a); } 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, tmp; tmp = 2; string str; char s[maxn]; while(cin >> str) { a = str; a = tmp * a; int cur = 1; for(int i = a.s.size()-1; i >= 0; --i) { s[cur++] = a.s[i] + '0'; } cout << a.SQRT(s) << "\n"; } return 0; }
如有不当之处欢迎指出!
URAL - 1153 Supercomputer 大数开方的更多相关文章
- ural 1153. Supercomputer
1153. Supercomputer Time limit: 2.0 secondMemory limit: 64 MB To check the speed of JCN Corporation ...
- Java中利用BigInteger类进行大数开方
在Java中有时会用到大数据,基本数据类型的存储范围已经不能满足要求了,如要对10的1000次方的这样一个数据规模的数进行开方运算,很明显不能直接用Math.sqrt()来进行计算,因为已经溢出了. ...
- ACM-ICPC2018焦作网络赛 Participate in E-sports(大数开方)
Participate in E-sports 11.44% 1000ms 65536K Jessie and Justin want to participate in e-sports. E- ...
- 蓝桥杯T126(xjb&大数开方)
题目链接:http://lx.lanqiao.cn/problem.page?gpid=T126 题意:中文题诶- 思路:显然被翻转了奇数次的硬币为反面朝上,但是本题的数据量很大,所以O(n^2)枚举 ...
- JAVA 大数开方模板
JAVA 大数开方模板 import java.math.BigInteger; import java.math.*; import java.math.BigInteger; import jav ...
- 大数开方 ACM-ICPC 2018 焦作赛区网络预赛 J. Participate in E-sports
Jessie and Justin want to participate in e-sports. E-sports contain many games, but they don't know ...
- ACM-ICPC 2018 焦作赛区网络预赛 J Participate in E-sports(大数开方)
https://nanti.jisuanke.com/t/31719 题意 让你分别判断n或(n-1)*n/2是否是完全平方数 分析 二分高精度开根裸题呀.经典题:bzoj1213 用java套个板子 ...
- Very simple problem - SGU 111(大数开方)
分析:使用的是构造新数字法进行不断构造,然后逼近每一位数字,然后使用c++徒手敲了240多行代码,竟然过了........................很有成就感. 代码如下: ========== ...
- 大数模板(Java)
大数加法 /* 给出2个大整数A,B,计算A+B的结果. Input 第1行:大数A 第2行:大数B (A,B的长度 <= 10000 需注意:A B有可能为负数) Output 输出A + B ...
随机推荐
- JavaScript中事件绑定的三种方式
JavaScript使得网页与用户友好交互,在使用 js 进行时间绑定的时候有三种绑定方式. 第一种:初学者以及普通写法 <div id="dom0"> <inp ...
- python初识-day2
1.模块初识 python中的库包括标准库和第三方库,需要使用时可直接导入,导入格式为"import 库模块",例如: import sys #sys为python的标准库 pr ...
- BSA Network Shell系列-nsh命令
nsh nsh命令软链接到zsh,直接运行nsh可进入Network Shell,所有的Network Shell命令都需要运行nsh进入Network Shell执行 1 使用cd命令访问远程主机和 ...
- junit4X系列--Assert与Hamcrest
原文出处:http://www.blogjava.net/DLevin/archive/2012/05/12/377960.html.感谢作者无私分享 到目前,JUnit4所有的核心源码都已经讲解过了 ...
- HSSF、XSSF和SXSSF区别以及Excel导出优化
之前有写过运用POI的HSSF方式导出数据到Excel(见:springMVC中使用POI方式导出excel至客户端.服务器实例),但这种方式当数据量大到一定程度时容易出现内存溢出等问题. 首先,PO ...
- MySQL存储过程中declare和set定义变量的区别
在存储过程中常看到declare定义的变量和@set定义的变量.简单的来说,declare定义的类似是局部变量,@set定义的类似全局变量. 1.declare定义的变量类似java类中的局部变量,仅 ...
- Codeforces C. Classroom Watch
C. Classroom Watch time limit per test 1 second memory limit per test 512 megabytes input standard i ...
- 浅析调用JSR303的validate方法, 验证失败时抛出ConstraintViolationException
废话不多说,直接进入正题:如何使用JSR303的validate,进行数据校验,失败后直接抛出异常加入流转信息中,并在form页面提示出来. 首先我们为了启用验证,需要向 项目中添加Bean验证的实现 ...
- jquery中ajax跨域提交的时候会有2次请求
我们平时在同域中请求页面什么的时候不会有这种情况,这种情况大多发生在移动端的跨域请求中发生的. 解决方法就是在服务端中加一层过滤HTTP请求的类型,把OPTION等不用的类型过滤掉.就是当请求为非 H ...
- 关于HTTP GET & POST的区别(转)
Http定义了与服务器交互的不同方法,最基本的方法有4种,分别是GET,POST,PUT,DELETE. URL全称是资源描述符,我们可以这样认为:一个URL地址,它用于描述一个网络上的资源,而HTT ...