jzoj3363
JYY 来到了一个新的城市,为了和大家保持联系,第一件事就是办理新的手机号。JYY 对号码的要求很高,希望大家都能够顺畅地阅读手机号,因此 JYY 特别研究了地球人的电话号码阅读习惯,有如下重大发现 (请自行代入你们的手机号码):地球人总是按照以下四种方式来朗读电话号码:
xxx-xxx-xxxxx 例如 151-958-83019
xxx-xxxx-xxxx 例如 151-9588-3019
xxxx-xxxx-xxx 例如 1519-5883-019
xxxx-xxx-xxxx 例如 1519-588-3019
即便是同一个电话号码,不同的人也会按照自己的习惯去解读,例如有些人会觉得电话号码是151-9588-3019,而有些却坚持 1519-588-3019。
为了让号码显得更上口,JYY 认为有些不吉利的数字串,在报电话号码时永远不应该被完整地读出来,例如,JYY 认为 7456 是不吉利的数字串 (气死我了),那么 13000007456 就是一个不好的号码,因为有人会把这个号码读作 130-000-07456,而在最后一次完整地读出了 7456。然而,13000745600 却不是一个不好的号码,因为无论怎么读,7456 都会被拆分开来。
现在给出 JYY 认为不吉利的数字串,请你计算满足 JYY 要求的电话号码,总共有多少个。具体来说说,一个好的电话号码满足以下要求:
电话号码是以 1 开头的 11 位数字串。
这个号码无论按照之前描述的 4 种读法中的哪个,都不能在任意时刻连续读出不吉利的数字串。
dp,設f[i][j]表示i位前五位為j的方案數,從後到前枚舉每一位
f[0][0]=1;枚舉更大的一位為0-9,f[i][nxt]=f[i-1][j]
然而有些方案不合法,要減去。我們可以考慮設常量數組a來表示不合法的狀態位置
則在i==a[i]的位置時,從前往後檢測是否不合法
預處理出一個數組g,g[i]表示與i相同的子串個數,且開頭從小到大在字符串的g[i][j]位
每次判定j時枚舉g的j,k位,當我們發現現在的g j k比b[l][0]要小,那麼可以取到這個值。f[i][j]不合法
最後取所有f[11][j%100000==1]的每一位即可
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll st[]={0,5,4,3,8,8,7,7,11,11},le[]={0,5,4,3,3,4,4,3,3,4},len[110],num[110],f[12][100010],n,tw[15],g[100010][110];
char s[110][20];
int main(){
tw[0]=1;
for(ll i=1;i<=13;i++)
tw[i]=tw[i-1]*10;
scanf("%lld",&n);
for(ll i=1;i<=n;i++){
scanf("%s",s[i]+1);
len[i]=strlen(s[i]+1);
for(ll j=len[i];j>=1;j--)
num[i]=num[i]*10+s[i][j]-'0';
}
f[0][0]=1;
for(ll i=1;i<=n;i++)
for(ll j=0;j<=99999;j++){
int v=0;
for(ll k=1;k<=6-len[i];k++)
if(j%tw[len[i]+k-1]/tw[k-1]==num[i]){
v=len[i]+k-1;
break;
}
if(v)g[j][++g[j][0]]=v;
}
for(ll i=1;i<=11;i++){
for(ll j=0;j<=99999;j++)
for(ll k=0;k<=9;k++)
f[i][j%10000*10+k]+=f[i-1][j];
for(ll j=1;j<=9;j++)
if(st[j]==i)
for(int k=0;k<=99999;k++)
if(f[i][k])
for(int l=1;l<=g[k][0];l++)
if(g[k][l]<=le[j]){
f[i][k]=0;
break;
}
}
ll ans=0;
for(ll i=0;i<=99999;i++)
if(i%10==1)
ans+=f[11][i];
printf("%lld",ans);
}
jzoj3363的更多相关文章
随机推荐
- super限定,子类中系统查找变量的顺序:
示例代码如下: import static java.lang.System.*; //-父类: class BaseClass{ public int a=7; } //-子类: public cl ...
- 2、C++
2.2定义变量 2.2.1命名规则 赋予变量的名称叫做标识符,或者更方便地称之为变量名.变量名可用字母(包括大小写),数字,以及下划线,其他字符不允许.以下划线或者字母开头.在Visual C++20 ...
- java--多线程编程简介
1.什么时候使用多线程编程 一个任务在正常情况下是按顺序执行的,但是如果当前任务里有多个相似进程块(例如for,while语句),我们就可以考虑把这些代码块抽出来并行运行,无需阻塞 2.实现多线程的几 ...
- php-生成数据库设计文档
在线以及提供下载数据库设计文档 $dbserver = "192.168.128.190:42578"; $dbusername = "root"; $dbpa ...
- 二进制搭建kubernetes多master集群【开篇、集群环境和功能介绍】
本文主要说明kubernetes集群使用组建的版本和功能介绍.. 一.组件版本 Kubernetes 1.12.3 Docker 18.06.1-ce Etcd 3.3.10 Flanneld 0.1 ...
- Kubernetes web界面kubernetes-dashboard安装
本文讲述的是如何部署K8s的web UI,前提是已经有一个k8s集群后,按照如下步骤进行即可.(如下步骤都是在master节点上进行操作) 1.下载kubernetes-dashboard.yaml文 ...
- centos6.5(64位)离线安装scalr
1.下载scalr-server安装备包: 下载地址:http://pan.baidu.com/s/1eSA3dom scalr-server-5.1.0.oss-nightly.2015013004 ...
- Redis配置总结
一:常用配置 1.bind,格式为bind 127.0.0.1:这个是很重要的配置,如果bind 127.0.0.1则外部网络是访问不了的(如果外部网络要访问还要开放端口) 2.port,格式为por ...
- windows开启禁用网卡
' 在Windows中实现sudo命令--命令行环境中获取管理员权限 'ShellExecute 方法 '作用: 用于运行一个程序或脚本. '语法 ' .ShellExecute "appl ...
- 编译hbase-1.2.3源代码
目录 目录 1 1. 约定 1 2. 安装jdk 1 3. 安装maven 1 4. 网络配置 2 4.1. eclipse 3 4.2. maven 3 5. 从hbase官网下载源代码包: 4 6 ...