UVA - 12333 字典树+大数
思路:用字典树将前40个数字记录下来,模拟大数加法即可。
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;
#pragma comment(linker, "/STACK:1024000000,1024000000")
#define eps 1e-10
#define inf 0x3f3f3f3f
#define PI pair<int, int>
typedef long long LL;
const int maxn = 10;
struct Node{
int num;
Node *next[maxn];
Node(){
num = -1;
for(int i = 0; i < maxn; i++) {
next[i] = NULL;
}
}
}*root;
void init() {
root = new Node();
}
void insert(int *a, int n, int num) {
n = min(n, 40);
Node *p = root, *q;
for(int i = 0; i < n; ++i) {
int x = a[i];
if(p->next[x] == NULL) {
q = new Node();
q->num = num;
p->next[x] = q;
}
p = p->next[x];
}
}
int find(char *a) {
Node *p = root;
int n = strlen(a);
for(int i = 0; i < n; ++i) {
int x = a[i] - '0';
if(p->next[x] == NULL) return -1;
p = p->next[x];
}
return p->num;
}
//高精度加法
const int Base = 100000000;
int a[2][20000+5], val[100];
int f = 0, h = 1;
stack<int>sta;
void Deal() {
memset(a, 0, sizeof(a));
a[0][0] = 1, a[1][0] = 1;
val[0] = 1;
int len[2] = {1,1};
insert(val, 1, 0);
for(int i = 2; i < 100000; ++i) {
int g = 0;
for(int j = 0; j < len[f] || j < len[h] || g > 0; ++j) {
int x = a[f][j] + a[h][j] + g;
a[f][j] = x % Base;
g = x / Base;
len[f] = max(len[f], j+1);
}
int cur = 0;
for(int j = len[f]-1; j >= 0; --j) {
if(cur >= 40) break;
int x = a[f][j];
if(j == len[f] - 1) {
while(x) {
sta.push(x % 10);
x /= 10;
}
}
else {
int u = 0, t = x;
while(t) {
++u;
t /= 10;
}
while(x) {
sta.push(x % 10);
x /= 10;
}
for(int k = 0; k < 8 - u; ++k) {
sta.push(0);
}
}
while(!sta.empty()) {
val[cur++] = sta.top();
sta.pop();
}
}
//insert
insert(val, cur, i);
f = 1 - f;
h = 1 - h;
}
}
int main() {
init();
Deal();
int T, kase = 1;
scanf("%d", &T);
char s[50];
while(T--) {
scanf("%s", s);
printf("Case #%d: %d\n", kase++, find(s));
}
return 0;
}
如有不当之处欢迎指出!
UVA - 12333 字典树+大数的更多相关文章
- UVA - 11488 字典树
题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem ...
- hdu 4099 Revenge of Fibonacci 字典树+大数
将斐波那契的前100000个,每个的前40位都插入到字典树里(其他位数删掉),然后直接查询字典树就行. 此题坑点在于 1.字典树的深度不能太大,事实上,超过40在hdu就会MLE…… 2.若大数加法时 ...
- UVa 12333 Revenge of Fibonacci (字典树+大数)
题意:给定一个长度小于40的序列,问你那是Fib数列的哪一项的前缀. 析:首先用大数把Fib数列的前100000-1项算出来,注意,一定不能是100000,要不然会WA的,然后每个数取前40位,不足4 ...
- UVA - 12333 Revenge of Fibonacci 高精度加法 + 字典树
题目:给定一个长度为40的数字,问其是否在前100000项fibonacci数的前缀 因为是前缀,容易想到字典树,同时因为数字的长度只有40,所以我们只要把fib数的前40位加入字典树即可.这里主要讨 ...
- UVa 12333 - Revenge of Fibonacci manweifc(模拟加法竖式 & 字典树)
题意: 给定n个(n<=40)数字, 求100000个以内有没有前面n个数字符合给定的数字的fibonacci项, 如果有, 给出最小的fibonacci项, 如果没有, 输出-1. 分析: 可 ...
- UVA 11732 strcmp() Anyone? (压缩版字典树)
题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem ...
- UVA 11488 Hyper Prefix Sets (字典树)
题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem ...
- UVA Phone List (字典树)(查询是否有前缀或自身是其他的前缀)
Phone List Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 16341 Accepted: 5228 Descr ...
- uva 11488 - Hyper Prefix Sets(字典树)
H Hyper Prefix Sets Prefix goodness of a set string is length of longest common prefix*number of str ...
随机推荐
- Node.js之事件监听和发送
演示事件的发送和监听 const events = require("events"); function Account() { this.balance = 0; events ...
- linkin大话面向对象--内部类
内部类说白了就是类中有类 内部类:嵌套类 外部类:宿主类 内部类主要有以下作用:记住了3个字:多继承... 1,内部类提供了更好的封装,可以把内部类隐藏在外部类中,不允许同一个包中的其他类访问该类. ...
- CSS常用字体名称
CSS样式中常用的字体名称 css中引入字体: @font-face { font-family: "AncientWar"; src: url('style/css/font ...
- func_get_args 获取一个函数的所有参数
func_get_args 获取一个函数的所有参数 { $numargs = func_num_args(); //参数数量 echo "参数个数是: $numargs&l ...
- 【C++】bazel的使用
bazel的使用 bazel是google开源的构建工具,可以支持多种语言的构建.这里来尝试一下如何在C++项目中使用bazel构建. 安装就不介绍了,在官网很详细,输入bazel --help: U ...
- 浏览器中页面的visibility状态及变化监听
需求 在浏览器中播放视频,当用户进行页面切换操作时.需要根据视频播放页是否处于可见状态,来控制视频的暂停及重新播放. 相关文档 参考MDN中,关于页面的可见性相关的API说明.https://deve ...
- ant基础[转]
原文链接:http://www.cnblogs.com/wufengxyz/archive/2011/11/24/2261797.html 1,什么是antant是构建工具2,什么是构建概念到处可查到 ...
- BZOJ 3670: [Noi2014]动物园 [KMP]
求这玩意: 对于字符串S的前i个字符构成的子串,既是它的后缀同时又是它的前缀,并且该后缀与该前缀不重叠,将这种字符串的数量记作num[i] 对1,000,000,007取模的结果 n≤5,L≤1,00 ...
- Windows Azure Platform Introduction (14) 申请海外的Windows Azure账户
<Windows Azure Platform 系列文章目录> 本文的最后更新时间为:2017-12-27 本文介绍国内用户,注册和使用海外Azure账户. 前提: 1.需要一个有效的Wi ...
- LeetCode - 492. Construct the Rectangle
For a web developer, it is very important to know how to design a web page's size. So, given a speci ...