zoukankan      html  css  js  c++  java
  • HDU 4099 Revenge of Fibonacci (数学+字典数)

    传送门:http://acm.hdu.edu.cn/showproblem.php?pid=4099

    这个题目就是一个坑或。

    题意:给你不超过40的一串数字,问你这串数字是Fibonacci多少的开头几位数字,如果不存在则输出-1.

    题解:明明说好的不超过40,但是在建字典数的时候不加i<41就超内存了,杭电你是想咋地,害的我比较好多人的代码,一点一点试出来的。

    AC代码:

    #include <iostream>
    #include <cstdio>
    #include <cstring>
    #include <string>
    #include <cstdlib>
    #include <cmath>
    #include <vector>
    #include <list>
    #include <deque>
    #include <queue>
    #include <iterator>
    #include <stack>
    #include <map>
    #include <set>
    #include <algorithm>
    #include <cctype>
    using namespace std;
    
    #define si1(a) scanf("%d",&a)
    #define si2(a,b) scanf("%d%d",&a,&b)
    #define sd1(a) scanf("%lf",&a)
    #define sd2(a,b) scanf("%lf%lf",&a,&b)
    #define ss1(s)  scanf("%s",s)
    #define pi1(a)    printf("%d
    ",a)
    #define pi2(a,b)  printf("%d %d
    ",a,b)
    #define mset(a,b)   memset(a,b,sizeof(a))
    #define forb(i,a,b)   for(int i=a;i<b;i++)
    #define ford(i,a,b)   for(int i=a;i<=b;i++)
    
    typedef __int64 LL;
    const int N=10;
    const int INF=0x3f3f3f3f;
    const double PI=acos(-1.0);
    const double eps=1e-7;
    
    char str[4][100];
    
    struct Trie
    {
        int v;
        Trie *next[N];
        Trie()
        {
            v=-1;
            for(int i=0;i<N;i++)
                next[i]=NULL;
        }
    }*root;
    
    void creat_trie(char s[],int x)
    {
        int len=strlen(s);
        Trie *p=root;
        for(int i=0;i<len&&i<41;i++)//这个地方太肯爹了,明明说好的不超过40,不加i<41就超内存了,杭电你是想咋地
        {
            int id=s[i]-'0';
            if(p->next[id]==NULL)
                p->next[id]=new Trie();
            p=p->next[id];
            if(p->v<0)
                p->v=x;
        }
    }
    
    void add(char a[],char b[],char c[])
    {
        int lena=strlen(a)-1,lenb=strlen(b)-1;
        int k=0,up=0;
        int x,y,z;
        while(lena>=0||lenb>=0)
        {
            if(lena<0) x=0;
            else x=a[lena]-'0';
    
            if(lenb<0)  y=0;
            else y=b[lenb]-'0';
            z=x+y+up;
            c[k++]=z%10+'0';
            up=z/10;
            lena--;
            lenb--;
        }
        if(up>0)    c[k++]=up+'0';
        c[k]=0;
        for(int i=0;i<k/2;i++)
            swap(c[i],c[k-i-1]);
    //    cout<<k<<" "<<c<<endl;system("pause");
    }
    
    int find_trie(char st[])
    {
        Trie *p=root;
        int len=strlen(st);
        int tmp;
        for(int i=0;i<len;i++)
        {
            int id=st[i]-'0';
            if(p->next[id]==NULL)
                return -1;
            else
            {
                p=p->next[id];
                tmp=p->v;
            }
        }
        return tmp;
    }
    
    void init()
    {
        str[1][0]='1';  str[1][1]=0;
        creat_trie(str[1],0);
        str[2][0]='1';  str[2][1]=0;
        creat_trie(str[2],1);
        for(int i=2;i<100000;i++)//注意题目是小于,不能取等号。。
        {
            int len1=strlen(str[1]);
            int len2=strlen(str[2]);
            if(len2>60)//舍去地位
            {
                str[2][len2-1]=0;
                str[1][len1-1]=0;
            }
            add(str[1],str[2],str[3]);
    
            creat_trie(str[3],i);
            strcpy(str[1],str[2]);
            strcpy(str[2],str[3]);
        }
    }
    
    int main()
    {
    //    freopen("input.txt","r",stdin);
        root=new Trie();
        init();
        int T,ca=0;
        char st[66];
        si1(T);
        while(T--)
        {
            ss1(st);
            printf("Case #%d: %d
    ",++ca,find_trie(st));
        }
        return 0 ;
    }
    


     

  • 相关阅读:
    图像有用区域--------深搜和广搜的第一次二选一
    24Pointgame-----24点游戏
    CAP定理和BASE理论
    并查集
    七桥问题和一笔画
    组合数问题--------一种新的 搜索 思路
    最少换乘 之简化版
    吝啬的国度 ---用vector 来构图
    WGZX:javaScript 学习心得--1
    eclipse Maven -->web project
  • 原文地址:https://www.cnblogs.com/suncoolcat/p/3343540.html
Copyright © 2011-2022 走看看