题意:

1 如果是严格升序的字母字符串,那么可以输出非0解码,否则不能译码输出0

2 字符串解码 遵循递增原则,其值为 到现在为止的所有按字母序小于该字符串的数量 + 1;

#include <iostream>

using namespace std;
char ans[11];
int a[10];
int c[27][27];
long long f[10];
void generc(){//生成组合数
for(int i=1;i<27;i++)c[i][0]=c[i][i]=1;
for(int i=2;i<27;i++){
for(int j=1;j<27;j++){
c[i][j]=c[i-1][j]+c[i-1][j-1];
}
}
}
void generf(){//如果字符串长度为len ,首先统计长度小于len的所有严格升序字符串个数
f[0]=0;
for(int i=1;i<10;i++){
f[i]=f[i-1]+c[26][i];//长度为i 的 字符串中会出现所有字母,且不重复取到i个后有唯一顺序
}
} long long calc(){
int len=0;//记录长度,不想用cstring
for(len=0;len<10;len++){
if(ans[len]==0)break;
a[len]=ans[len]-'a';//习惯处理数字,无关紧要
} int former=0;//记录前一位的值+1,该值将作为下一位所有可能的起点,因为是首位,设存在a[-1]=-1;所以a[0]从0('a')开始
long long res=0;//记录答案
res+=f[len-1];//记录所有长度小于len的严格升序字母字符串
for(int i=0;i<len;i++){//记录所有第i位按字母序小于a[i]的字符串
for(int j=former;j<a[i];j++){//
res+=c[25-j][len-1-i];//25-j 可用字母数量 len-1-i 还未确定的字母个数 由于题意保证,不需要加条件判断正确性
}
former=a[i]+1;
}
return res+1;//只记录了比自己小的字符串所以+1
}
bool check(){//检验是否严格升序,没看清题意忘了检验,wa第一次
int fl=true;
int len=0;
char former='a'-1;
for(len=0;len<10;len++){
if(ans[len]==0)break;
if(ans[len]<=former){
fl=false;
break;
}
former=ans[len];
}
if(len==0)return false;//无关紧要
return fl;
}
int main(){
generc();
generf();
cin>>ans;//只有一组数据,wa第二次
if(check())cout<<calc()<<endl;
else cout<<0<<endl;
return 0; }

  

这道题虽然水,但反映了我不读题意的问题,我写的也不好,接下来去找大神题解去

解法2  看了题解后的新想法,dp,但是悲哀的是忘了former的存在//16ms

#include <iostream>
using namespace std;
char ans[11];
int a[10];
int len;
long long memo[11][27];//memo[i][j] i 当前长度 j 以何种字母开头 (j=26相当于所有字母皆可的'X')
//memo[i][j] 长度<i && 字典序 小于j 的所有严格升序字符串
void setmemo(){
//memo[1][0]=0;//a前面没有 符合条件的字符串
for(int i=1;i<27;i++)memo[1][i]=memo[1][i-1]+1;
for(int i=2;i<11;i++){
//memo[i][0]=0;
for(int j=1;j<26;j++){
memo[i][j]=memo[i][j-1]+memo[i-1][26]-memo[i-1][j];//所有可能减去小于j的可能
}
memo[i][26]=memo[i][25];//任何长度>1的字符串首位必然不是z
}
}
long long calc(){
long long ans=0; for(int i=0;i<len;i++){
ans+=memo[len-i][a[i]];
if(i)ans-=memo[len-i][a[i-1]+1];
ans+=memo[i][26];
}
return ans+1;
}
bool check(){
bool fl=true;
char former='a'-1;
for(len=0;len<10;len++){
if(ans[len]==0)break;
if(ans[len]<=former){
fl=false;
break;
}
a[len]=ans[len]-'a';
former=ans[len];
}
if(len==0)return false;
return fl;
}
int main(){
setmemo();
while(cin>>ans){
if(check())cout<<calc()<<endl;
else cout<<0<<endl;}
return 0;
}

  

POJ 1850 Code 字符串 难度:1的更多相关文章

  1. POJ 1850 Code(组合数)

    http://poj.org/problem?id=1850 题意 :给定字符串,系统是用字符串组成的,字符串是按字典序排的.编码系统有三条规则,1这些的单词的长度是由小到大的,2相同长度的按字母在字 ...

  2. POJ 1850 Code

    组合数学.... Code Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 7202 Accepted: 3361 Descrip ...

  3. poj 1850 code(组合数学)

    题目:http://poj.org/problem?id=1850 题意:按给定的规则给字母编号. 一个很简单的题目,但是却做了好久.................................. ...

  4. POJ 1850 Code(找规律)

    Code Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 7913   Accepted: 3709 Description ...

  5. POJ - 1850 Code(组合数学)

    https://vjudge.net/problem/POJ-1850 题意 输出某字符串在字典中的位置.字符串不合规则时输出0. 分析 首先判断字符串合法性,也就是判断是不是升序排列的.如果符合,以 ...

  6. poj:1850 Code(组合数学?数位dp!)

    题目大意:字符的字典序依次递增才是合法的字符串,将字符串依次标号如:a-1 b-2 ... z-26 ab-27 bc-52. 为什么题解都是组合数学的...我觉得数位dp很好写啊(逃 f[pos][ ...

  7. 【POJ 1850】 Code

    [POJ 1850] Code 还是非常想说 数位dp真的非常方便! !. 数位dp真的非常方便!.! 数位dp真的非常方便! !! 重要的事说三遍 该题转换规则跟进制差点儿相同 到z时进一位 如az ...

  8. POJ 1496 POJ 1850 组合计数

    Code Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 8256 Accepted: 3906 Description Tran ...

  9. POJ 1159 Palindrome(字符串变回文:LCS)

    POJ 1159 Palindrome(字符串变回文:LCS) id=1159">http://poj.org/problem? id=1159 题意: 给你一个字符串, 问你做少须要 ...

随机推荐

  1. 简单的php性能注意点

    什么情况,可能遇到性能问题: 1.php语法使用的不恰当 2.使用php语言做了它不擅长做的事 3.用php语言连接的服务不给力 4.php自身的短板 5.我也不知道的问题 一般情况:php性能问题不 ...

  2. Java中的Swing键盘绑定案例

    package ch12; import javax.swing.*; import java.awt.*; import java.awt.event.*; /** * Created by Jiq ...

  3. PLSQL Developer连接远程Oracle方法(非安装客户端)

    Oracle比较麻烦,通常需要安装oracle的客户端才能实现.通过instantclient可以比较简单的连接远程的Oracle. 1.新建目录D:\Oracle_Cleint用于存放相关文件,新建 ...

  4. kvm相关文章

    配置KVM虚拟机的网络 Bridge和Nat方式http://www.it165.net/os/html/201503/12231.html KVM虚拟机网络配置 Bridge方式,NAT方式 htt ...

  5. OpenGL的glViewPort窗口设置函数实现分屏

    之前实现过全景图片查看(OpenGL的几何变换3之内观察全景图),那么我们需要进行分屏该如何实现呢?如下图: 没错就是以前提过的glViewPort函数,废话不多说了,我直接上代码: //从这里开始进 ...

  6. 基于dubbo源码包通过Maven构建dubbo的详细步骤

    通过Maven构建dubbo 既然可以下载得到源码以及发布包,那么为什么要去构建dubbo呢?,我们先来看下dubbo的主要模块: 我们不仅要使用dubbo的核心框架,还要使用它的一些服务,比如管理控 ...

  7. JavaScript:引用js文件时的编码格式问题

    JavaScript:引用js文件时的编码格式问题 如果js文件的编码格式是utf-8,并且含有中文,那么按照正常的方法引用,就会出现乱码的情况. 方法/步骤   如果js文件的编码格式是utf-8, ...

  8. dom jaxp详解

    转自 http://blog.csdn.net/java958199586/article/details/7277904 一.XML解析技术概述 1.XML解析方式分为两种:dom和sax (1)d ...

  9. OpenCV C++ 计算文件夹中对象文件数目及批量处理后保存到txt文件

    //采用windows控制台实现计算文件夹中对象总数以及批量读取对象 //#include <afx.h> //和windows.h是一样的作用 #include <opencv2/ ...

  10. OpenCV3编程入门笔记(4)腐蚀、膨胀、开闭运算、漫水填充、金字塔、阈值化、霍夫变换

    腐蚀erode.膨胀dilate 腐蚀和膨胀是针对图像中的白色部分(高亮部分)而言的,不是黑色的.除了输入输出图像外,还需传入模板算子element,opencv中有三种可以选择:矩形MORPH_RE ...