zoukankan      html  css  js  c++  java
  • 【递归与递推】编码

    【递归与递推】编码

    题目描述

    编码工作常被运用于密文或压缩传输。这里我们用一种最简单的编码方式进行编码:把一些有规律的单词编成数宇。

    字母表中共有26个字母{a,b,…,z},这些特殊的单词长度不超过6且字母按升序排列。把所有这样的单词放在一起,按字典顺序排列,一个单词的编码就对应着它在字典中的位置。

    例如:
        a→1    b→2    z→26    ab→27    ac→28

    你的任务就是对于所给的单词,求出它的编码。

    输入

    仅一行,被编码的单词。

    输出

    仅一行,对应的编码。如果单词不在字母表中,输出0。

    样例输入

    ab
    

    样例输出

    27
    分析:先检查单词是否符合要求;
    统计1,2...len-1的个数分别为C(26,1)+C(26,2)...+C(26,len-1),到当前长度暴搜即可;
    代码:
    #include <iostream>
    #include <cstdio>
    #include <cstdlib>
    #include <cmath>
    #include <algorithm>
    #include <climits>
    #include <cstring>
    #include <string>
    #include <set>
    #include <map>
    #include <queue>
    #include <stack>
    #include <vector>
    #include <list>
    #include <ext/rope>
    #define rep(i,m,n) for(i=m;i<=n;i++)
    #define rsp(it,s) for(set<int>::iterator it=s.begin();it!=s.end();it++)
    #define vi vector<int>
    #define pii pair<int,int>
    #define mod 1000000007
    #define inf 0x3f3f3f3f
    #define pb push_back
    #define mp make_pair
    #define fi first
    #define se second
    #define ll long long
    #define pi acos(-1.0)
    const int maxn=10;
    const int dis[][2]={0,1,-1,0,0,-1,1,0};
    using namespace std;
    using namespace __gnu_cxx;
    ll gcd(ll p,ll q){return q==0?p:gcd(q,p%q);}
    ll qpow(ll p,ll q){ll f=1;while(q){if(q&1)f=f*p;p=p*p;q>>=1;}return f;}
    int n,m,len;
    string a,b;
    ll cnt;
    ll work(int p)
    {
        ll ans=1;
        p=max(p,26-p);
        for(int i=26;i>=p+1;i--)ans*=i;
        for(int i=1;i<=26-p;i++)ans/=i;
        return ans;
    }
    bool check(string p)
    {
        if(len>6)return false;
        else
        {
            string q=p;
            sort(q.begin(),q.end());
            if(q!=p||unique(q.begin(),q.end())!=q.end())return false;
            return true;
        }
    }
    void dfs(string p,char x,int now)
    {
        if(now==len)
        {
            cnt++;
            if(p==a)exit(0*printf("%lld
    ",cnt));
            return;
        }
        for(char q=x+1;q<='z';q++)dfs(p+q,q,now+1);
    }
    int main()
    {
        int i,j,k,t;
        cin>>a;
        len=a.length();
        if(check(a)==false)exit(0*puts("0"));
        for(i=1;i<=len-1;i++)cnt+=work(i);
        dfs("a",'a',1);
        printf("%lld
    ",cnt);
        //system("pause");
        return 0;
    }
     
  • 相关阅读:
    程序员修炼之道:从小工到专家
    2020.12.16收获
    2020.12.15收获
    2020.12.14收获
    2020.12.13收获
    Android学习第二天——对Android的简单了解
    Java学习12.18
    考试加分项
    Java学习12.17
    Java建议
  • 原文地址:https://www.cnblogs.com/dyzll/p/5645456.html
Copyright © 2011-2022 走看看