UVa 12333 - Revenge of Fibonacci manweifc(模拟加法竖式 & 字典树)
题意:
给定n个(n<=40)数字, 求100000个以内有没有前面n个数字符合给定的数字的fibonacci项, 如果有, 给出最小的fibonacci项, 如果没有, 输出-1。
分析:
可以将这个问题分为两个部分:
①求出10万个fibonacci数列的前40个数字
②查找给定的数在不在这些数字里面
对于第一个部分, 我们可以模拟竖式加法(可以用滚动数组节省内存), 然后因为只是需要前40位,而且fibonacci数列上升速度很快, 所以我们保留60位的精度就足够了。
对于第二部分,可以构造字典树,用数组模拟可以避免指针带来的不必要出错。
- #include <bits/stdc++.h>
- using namespace std;
- struct Node
- {
- int id;
- int next[];
- Node(){
- id = -;
- for(int i = ; i < ; i++)
- {
- next[i] = -;
- }
- }
- };
- Node trie[];
- int cnt = ;
- const Node root = trie[cnt++];
- void add_node(const char str[], int id)
- {
- int index = ;
- for(int i = , len = strlen(str); i < len; i++)
- {
- int v = str[i] - '';
- if((trie[index].next[v] == -))
- {
- trie[index].next[v] = cnt;
- index = cnt;
- cnt++;
- }
- else {
- index = trie[index].next[v];//如果存在直接去到下一个节点
- }
- if(trie[index].id == -){
- trie[index].id = id;
- }
- }
- }
- int Find(const char str[])
- {
- int index = ;
- for(int i = , len = strlen(str); i < len; i++)
- {
- int v = str[i] - '';
- if(v < ) return -;
- if(trie[index].next[v] == -)
- {
- return -;
- }
- index = trie[index].next[v];
- }
- return trie[index].id;
- }
- int main()
- {
- char t[];
- memset(t,,sizeof(t));
- int fib[][];
- add_node((char*)"",);
- int p, q, s, l;
- s = ; l = ;
- fib[][] = ;
- fib[][] = ;
- for(int f = ; f < ; f++){
- p = f&, q = (f+) &; //滚动数组
- for(int i = s; i < l; i++){
- fib[p][i] = fib[p][i] + fib[q][i];
- if(fib[p][i] >= ){
- fib[p][i+]++;
- fib[p][i] -= ;//进位了记得要减回来
- if(i == l-){
- l++;//如果最后一位还要进位 那么位数+1
- }
- }
- }
- if(l - s > ) s++;//保留前60位的精度
- int cnt = ;
- for(int i = l - ; i >= s && cnt < ; i--)
- {
- t[l-i-] = fib[p][i]+'';
- cnt++;
- }
- add_node((char*)t,f);//截取前40个数字构造字典树
- memset(t,,sizeof(t));
- }
- int tt;
- scanf("%d", &tt);
- int kase = ;
- char que[];
- while(tt--)
- {
- scanf("%s", que);
- printf("Case #%d: %d\n",kase++, Find(que));
- }
- }
UVa 12333 - Revenge of Fibonacci manweifc(模拟加法竖式 & 字典树)的更多相关文章
- UVA - 12333 Revenge of Fibonacci 高精度加法 + 字典树
题目:给定一个长度为40的数字,问其是否在前100000项fibonacci数的前缀 因为是前缀,容易想到字典树,同时因为数字的长度只有40,所以我们只要把fib数的前40位加入字典树即可.这里主要讨 ...
- UVA 12333 Revenge of Fibonacci
https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- UVA - 12333 Revenge of Fibonacci (大数 字典树)
The well-known Fibonacci sequence is defined as following: F(0) = F(1) = 1 F(n) = F(n − 1) + F(n − 2 ...
- UVa 12333 Revenge of Fibonacci (字典树+大数)
题意:给定一个长度小于40的序列,问你那是Fib数列的哪一项的前缀. 析:首先用大数把Fib数列的前100000-1项算出来,注意,一定不能是100000,要不然会WA的,然后每个数取前40位,不足4 ...
- pat(A) 2-06. 数列求和(模拟摆竖式相加)
1.链接:http://www.patest.cn/contests/ds/2-06 2.思路:模拟摆竖式相加,因为同样位置上的数字同样,那么同一位上的加法就能够用乘法来表示 3.代码: #inclu ...
- 校内模拟赛 : Rima —— 字典树+树形DP
首先说一下,对一个刚学Trie树的蒟蒻来说(就是我),这道题是一道好题.Trie树比较简单,所以就不详细写了. Rima 内存限制:256 MiB 时间限制:1000 ms 标准输入输出 题目类型:传 ...
- hdu 4099 Revenge of Fibonacci Trie树与模拟数位加法
Revenge of Fibonacci 题意:给定fibonacci数列的前100000项的前n位(n<=40);问你这是fibonacci数列第几项的前缀?如若不在前100000项范围内,输 ...
- UVA-12333 Revenge of Fibonacci(竖式加法模拟 & 字典树)
题目: 给出一个斐波那契数字的前缀,问第一个有这个前缀的数字在斐波那契数列中是第几个. 思路: 紫书提示:本题有一定效率要求.如果高精度代码比较慢,可能会超时. 利用滚动数组和竖式加法来模拟斐波那契相 ...
- HDU4099 Revenge of Fibonacci(高精度+Trie)
Revenge of Fibonacci Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 204800/204800 K (Java/ ...
随机推荐
- PostgreSQL 9.6.2版本在centOS下的安装和配置
1.如果有用yum安装过旧版,卸载掉: yum remove postgresql* 2.更新一下yum: sudo yum update 3.去 官网 找到 适合你系统 的资源的下载地址,然后使用w ...
- JavaScript编程艺术-第7章代码汇总(1)
1.document.write()(HTML与JS未分离) HTML: JS: 2..innerHTML(直接覆盖) HTML: JS: 3.getAttribute.setAttribute.ge ...
- play framework
Compilation errorThe file {module:docviewer}/app/controllers/PlayDocumentation.java could not be com ...
- Poj 3294 Life Forms (后缀数组 + 二分 + Hash)
题目链接: Poj 3294 Life Forms 题目描述: 有n个文本串,问在一半以上的文本串出现过的最长连续子串? 解题思路: 可以把文本串用没有出现过的不同字符连起来,然后求新文本串的heig ...
- how-to-fix-fs-re-evaluating-native-module-sources-is-not-supported-graceful
http://stackoverflow.com/questions/37346512/how-to-fix-fs-re-evaluating-native-module-sources-is-not ...
- glassfish应用服务器安装配置
1.Glassfish4.0下载地址:https://glassfish.java.net/download.html#gfoseTab 2.将下载的glassfish-4.0.zip传输到服务器/h ...
- CentOS 6.5使用:[3]使用xftp传递文件
先检查CentOS系统是否安装了FTP服务 [root@centos ~]# rpm -qa | grep vsftpd 如果有内容输出,那么恭喜你,你的系统已经安装了ftp服务 如果没有那么按照 ...
- 188 Best Time to Buy and Sell Stock IV 买卖股票的最佳时机 IV
假设你有一个数组,其中第 i 个元素是第 i 天给定股票的价格.设计一个算法来找到最大的利润.您最多可以完成 k 笔交易.注意:你不可以同时参与多笔交易(你必须在再次购买前出售掉之前的股票). 详见: ...
- quazip非静态成员。。错误
转载请注明出处:http://www.cnblogs.com/dachen408/p/7147155.html 问题:quazip非静态成员..错误 解决方案:quazip_global.h 第42 ...
- 重装macOS环境配置笔记
由于早些年买mac的时候写代码的经验还不够,导致多年使用后mac上装满了乱七八糟的软件,比如python就有系统自带的,xcode里的,pyenv的,以及brew安装的各种版本,nginx,Apach ...