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 ...
随机推荐
- scrapy_items
为什么要items? 当数据量多的时候,没有统一的数据管理,统一格式化麻烦 items中除了能添加字段,还能做什么? 1. 进行预先处理 2. 对从items出去的数据进行处理 3. 写上sql语句逻 ...
- junit4X系列--Runner解析
前面我整理了junit38系列的源码,那junit4X核心代码也基本类似.这里我先转载一些关于junit4X源码解析的好文章.感谢原作者的分享.原文地址:http://www.blogjava.net ...
- junit测试延伸--私有方法测试
关于junit测试的延伸,这里有类概念级别的测试,继承类的测试,接口的测试,抽象类的测试,关于这些类级别的测试,这里我就不做多的赘述了. 关于上面的几个测试就是说,我们不应该单纯的去测试类中的一些方法 ...
- 通过编程为Outlook 2007添加邮件规则
Outlook 所支持的邮件规则相当有用,我们经常需要针对某些特征的邮件做特殊的处理.例如将其移动到某个特定文件夹,或者删除它等等. Outlook所支持的邮件规则主要两大类:收到邮件时和发送邮件时 ...
- ORACLE对象大小写问题
在数据库新建一个测试表(数据库版本为ORACLE 10.2.0.1.0),表名为小写的test. 脚本如下所示: CREATE TABLE test( id NUMBER(10), ...
- android EditText与TextView几个常用的属性
android:maxLength="100"输入框最多输入的字数. android:maxEms="10"每行最多输入字符个数 android:textcol ...
- C++——函数重载
C++允许功能相近的函数在相同的作用域内以相同函数名声明,从而形成重载,方便使用,便于记忆. /*形参类型不同*/ int add(int x,int y); float add(float x,fl ...
- 关于OMAPL138烧写程序的说明
相信很多朋友在用CCS调试OMAPL138开发板的时候,肯定遇到了许许多多的问题: 例如: 1.CCS安装不完整,导致有些功能无法使用 2.ARM端没有加载gel文件,使得程序无法被唤醒 3.ccxm ...
- SpringMVC和Struts2的比较
整体的框架机制 1.Struts2的入口是StrutsPrepareAndExecuteFilter,SpringMVC的入口是通过DispatcherServlet实现. 2.Str ...
- js实现文本框输入文字个数限制代码
html: <div class="curr_eval_box"> <input type="hidden" n ...