hdu 4099 Revenge of Fibonacci(字典树)

2024-06-05 01:48

本文主要是介绍hdu 4099 Revenge of Fibonacci(字典树),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:hdu 4099 Revenge of Fibonacci

题目大意:给定一个前缀,找到最小的n,保证f(n)包含前缀。f为斐波那契数列,要求n小于100000。

解题思路:大数加法,对100000以内的斐波那契数预处理出前缀,这里处理的时候只需要对前50位进行加法处理即

可,否则复杂度过高,因为查询的长度不会超过40。然后建立字典树,查询则在字典树上进行搜索。

#include <cstdio>
#include <cstring>
#include <algorithm>using namespace std;
const int maxn = 1e6 + 5;
const int sigma_size = 10;struct Bign {int c, s[maxn];Bign() {}void operator = (int a) {c = 0;memset(s, 0, sizeof(s));while (a) {s[c++] = a % 10;a /= 10;}}void put() {for (int i = 1; i <= 40 && i <= c; i++)printf("%d", s[c-i]);printf("\n");}
}num[3];void add(const Bign& a, const Bign& b, Bign& ans) {int tmp = 0;ans.c = max(a.c, b.c);for (int i = max(min(a.c, b.c) - 50, 0); i < a.c || i < b.c; i++) {if (i < a.c) tmp += a.s[i];if (i < b.c) tmp += b.s[i];ans.s[i] = tmp % 10;tmp /= 10;}while (tmp) {ans.s[ans.c++] = tmp % 10;tmp /= 10;}
}struct Tire {int sz, g[maxn * 10][sigma_size];int val[maxn * 10];void init();int find(char* s);void insert(const Bign& a, int x);
}T;void init () {num[0] = 1;num[1] = 1;T.init();T.insert(num[0], 1);T.insert(num[1], 2);int t = 2;for (int i = 2; i < 100000; i++) {add(num[(t+1)%3], num[(t+2)%3], num[t]);T.insert(num[t], i + 1);t = (t + 1) % 3;}
}int main () {init();int cas;char s[60];;scanf("%d", &cas);for (int kcas = 1; kcas <= cas; kcas++) {scanf("%s", s);printf("Case #%d: %d\n", kcas, T.find(s) - 1);}return 0;
}void Tire::init() {sz = 1;val[0] = 0;memset(g[0], 0, sizeof(g[0]));
}int Tire::find(char* s) {int n = strlen(s), u = 0;for (int i = 0; i < n; i++) {int v = s[i] - '0';if (g[u][v] == 0)return 0;u = g[u][v];}return val[u];
}void Tire::insert(const Bign& a, int x) {int u = 0;for (int i = 1; i <= 40 && i <= a.c; i++) {int v = a.s[a.c - i];if (g[u][v] == 0) {val[sz] = x;memset(g[sz], 0, sizeof(g[sz]));g[u][v] = sz++;}u = g[u][v];}
}

这篇关于hdu 4099 Revenge of Fibonacci(字典树)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1031730

相关文章

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

poj 3974 and hdu 3068 最长回文串的O(n)解法(Manacher算法)

求一段字符串中的最长回文串。 因为数据量比较大,用原来的O(n^2)会爆。 小白上的O(n^2)解法代码:TLE啦~ #include<stdio.h>#include<string.h>const int Maxn = 1000000;char s[Maxn];int main(){char e[] = {"END"};while(scanf("%s", s) != EO

hdu 2093 考试排名(sscanf)

模拟题。 直接从教程里拉解析。 因为表格里的数据格式不统一。有时候有"()",有时候又没有。而它也不会给我们提示。 这种情况下,就只能它它们统一看作字符串来处理了。现在就请出我们的主角sscanf()! sscanf 语法: #include int sscanf( const char *buffer, const char *format, ... ); 函数sscanf()和

hdu 2602 and poj 3624(01背包)

01背包的模板题。 hdu2602代码: #include<stdio.h>#include<string.h>const int MaxN = 1001;int max(int a, int b){return a > b ? a : b;}int w[MaxN];int v[MaxN];int dp[MaxN];int main(){int T;int N, V;s

hdu 1754 I Hate It(线段树,单点更新,区间最值)

题意是求一个线段中的最大数。 线段树的模板题,试用了一下交大的模板。效率有点略低。 代码: #include <stdio.h>#include <string.h>#define TREE_SIZE (1 << (20))//const int TREE_SIZE = 200000 + 10;int max(int a, int b){return a > b ? a :

hdu 1166 敌兵布阵(树状数组 or 线段树)

题意是求一个线段的和,在线段上可以进行加减的修改。 树状数组的模板题。 代码: #include <stdio.h>#include <string.h>const int maxn = 50000 + 1;int c[maxn];int n;int lowbit(int x){return x & -x;}void add(int x, int num){while

hdu 3790 (单源最短路dijkstra)

题意: 每条边都有长度d 和花费p,给你起点s 终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费最少的。 解析: 考察对dijkstra的理解。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstrin

hdu 2489 (dfs枚举 + prim)

题意: 对于一棵顶点和边都有权值的树,使用下面的等式来计算Ratio 给定一个n 个顶点的完全图及它所有顶点和边的权值,找到一个该图含有m 个顶点的子图,并且让这个子图的Ratio 值在所有m 个顶点的树中最小。 解析: 因为数据量不大,先用dfs枚举搭配出m个子节点,算出点和,然后套个prim算出边和,每次比较大小即可。 dfs没有写好,A的老泪纵横。 错在把index在d

hdu 1102 uva 10397(最小生成树prim)

hdu 1102: 题意: 给一个邻接矩阵,给一些村庄间已经修的路,问最小生成树。 解析: 把已经修的路的权值改为0,套个prim()。 注意prim 最外层循坏为n-1。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstri

hdu 1285(拓扑排序)

题意: 给各个队间的胜负关系,让排名次,名词相同按从小到大排。 解析: 拓扑排序是应用于有向无回路图(Direct Acyclic Graph,简称DAG)上的一种排序方式,对一个有向无回路图进行拓扑排序后,所有的顶点形成一个序列,对所有边(u,v),满足u 在v 的前面。该序列说明了顶点表示的事件或状态发生的整体顺序。比较经典的是在工程活动上,某些工程完成后,另一些工程才能继续,此时