The Alphabet Sticker
题目大意:给你一串字符串,其中有一部分未知,用’?’表示。
现在定义一种合法的Sticker,比如”aabcc”,“ccccab”。即所有相同的字母要在一起才是合法的。现在请问对于给定的字符串,有多少种合法的结果。
比如:”aa??bb”合法的字符串有三种。
分别是“aaaabb” “aaabbb” ”aabbbb”.
‘?’表示的字符只能从已经给出的字符中选,所以”aaccbb”是不合法的。
由于最终结果很大,所以把结果对 1e9+7取模。
题目看懂之后思路就很明确了,一个组合问题。
分析一下:
1、相同字母需要在一起
2、只能从存在的字母中选。
显然的,‘?’只能从左边或者右边的字母中选取。
‘?’出现的情况有一下几种(打引号好累):???xx xxx?? xx??xx xx?yy
第一种和第二种是一样的,因为出现在序列首/尾部。这两种情况只有1种。
第三种:只有一种,必须和x一样。
第四种:这个情况比较多,但是很容易感觉到会与‘?’的个数有关,来找下规律
aaa?bbb 长度 1 种数 2 aaaabbb aaabbbb
aaa??bbb 长度 2 种数 3 aaaaabbb aaaabbbb aaabbbbb
aaa???bbb 长度 3 种数 4 aaaaaabbb aaaaabbbb aaaabbbbb aaabbbbbb
规律很快就的出来了,种数 = 长度 + 1。
好了,所有‘?’出现的情况都分析过了,下面利用组合数学的知识,对于每一部分‘?’的种数应该乘起来求组合数。只需要在乘的过程中记得对mod取余,防止溢出就好了~
等下,是不是还忘记了一种情况。
我们默认认为数据都是合法的字符串,但是如果给你的就是一个不合法的字符串,那么这时候就应该输出0。
下面附上代码:
/*
* Problem: A
* Date: 2014-7-20
* Author: Wuhen
*/
#include <map>
#include <list>
#include <queue>
#include <string>
#include <vector>
#include <cstdarg>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <iostream>
#include <algorithm>
#define LL long long
#define Clean(a) memset(a, 0, sizeof(a)) using namespace std;
bool vis[300];
const LL mod = 1e9+7;
LL deal(LL len, char l, char r)
{
if (l == r) return 1;
else return (len+1)%mod;
} int main()
{
LL T;
cin >> T;
while(T--)
{
string s;
cin >> s;
Clean(vis);
LL all = 0;
for (LL i = 0; i < s.size(); i++)
{
if (s[i] == '?') continue;
if (vis[s[i]] == 0)
{
all += 1;
vis[s[i]] = 1;
}
else
{
LL find = i-1;
while(s[find] == '?' && find >= 0) find--;
if (s[find] != s[i])
{
all = 0;
break;
}
}
}
if (all == 0)
{
puts("0");
continue;
}
LL res = 1;
LL start = 0, stop = s.size() - 1;
while(s[start] == '?' && start < s.size()) start++;
while(s[stop] == '?' && stop >= 0) stop--;
for (LL i = start; i <= stop; i++)
{
if (s[i] != '?') continue;
char left = s[i-1];
LL len = 0;
while(s[i] == '?' && i <= stop)
{
len++;
i++;
}
res *= deal(len, left, s[i]);
res %= mod;
}
cout << res%mod << endl;
}
return 0;
}
The Alphabet Sticker的更多相关文章
- 字符串-Alphabet
在一些应用当中,会对字符串的字母表进行限制,在这些应用中,往往会用到如下的示例所涉及到的几点知识: public static void main(String[] args){ String[] a ...
- Sticker.js – 帮助你在网站中加入贴纸效果
Sticker.js 是一个很小的 JavaScript 库,它允许您在网页中创建漂亮的贴纸效果.没有依赖关系(不需要 jQuery),可以在大多数支持 CSS3 的主流浏览器工作.下面有简单的使用示 ...
- session204 imessageApp sticker part I要点
session204 imessageApp sticker partI 工程文件:https://developer.apple.com/library/prerelease/content/sam ...
- Codeforces Round #337 Alphabet Permutations
E. Alphabet Permutations time limit per test: 1 second memory limit per test: 512 megabytes input: ...
- sticker.js贴纸效果
http://stickerjs.cmiscm.com/ <div class="sticker gbtags"></div> <!-- 引用Java ...
- Amazon.com: NEW VI AND VIM EDITOR KEYBOARD STICKER: Office Products
Amazon.com: NEW VI AND VIM EDITOR KEYBOARD STICKER: Office Products NEW VI AND VIM EDITOR KEYBOARD S ...
- App Extensions篇之Sticker Pack Extension
转载请标明原文链接:http://www.cnblogs.com/zhanggui/p/7151795.html 前言 上一篇文章对App Extension做了简单介绍以及对Share Extens ...
- 福布斯最佳雇主榜:谷歌母公司Alphabet再登榜首 微软次之
http://www.sohu.com/a/259018538_114774 站长之家(ChinaZ.com) 10月12日 消息:在福布斯发布的最新全球最佳雇主榜单中,谷歌母公司Alphabet以满 ...
- English Phonetic Spelling Alphabet
https://www.englishclub.com/vocabulary/english-phonetic-spelling.htm When speaking on the telephone ...
随机推荐
- Codeforces 680D - Bear and Tower of Cubes
680D - Bear and Tower of Cubes 思路:dfs+贪心,设剩余的体积为res,存在a,使得a3 ≤ res,每次取边长为a的立方体或者边长为a-1的立方体(这时体积上限变成a ...
- SGE:qsub/qstat/qdel/qhost 任务投递和监控
参考: Oracle Grid Engine qsub命令 SGE - qsub使用范例 SGE作业基本用法 qsub是最为稳定的底层任务投递系统,就是把一个脚本投递到集群的计算节点上运行. 注意,只 ...
- ArcGIS API for Silverlight 的重要内容******重要
ArcGIS Silverlight API:是构建在微软Silverlight平台之上,通过ArcGIS Server Rest API消费ArcGIS Server 服务,同时支持直接消费Bing ...
- English trip -- Phonics 6 元音字母 u + Unit 5 B课 review
Vowel u [ʌ] 闭音节 bunny cut bug mushroom lunch ar er ur or ir = R (读音类似儿) e.g. dollar 美元 collar n. ...
- Shell脚本中点号+文件名的作用
熟悉linux是程序员必须具备的技能,水滴石穿,一点点学习吧. linux中一个文件是根据其是否具有执行属性来判断他是否可以直接运行的.就像windows下的exe一样. 如果我们要执行某一个文件,可 ...
- 浏览器对应用程序的根URL发出请求时所发生的情况(结合 DI)
1. 浏览器向 MVC 框架发送一个请求 Home 的 URL,MVC 准备创建 HomeController 类的实例. 2. MVC 框架在创建 HomeController 类实例过程中会发现其 ...
- spting Boot 创建一个springBoot项目
spting Boot 创建一个springBoot项目 1)学习springBoot使用软件:IDEA软件(前面的文章有安装idea的过程). 也可以使用另一种方法在https://start.sp ...
- Intel DAAL AI加速——支持从数据预处理到模型预测,数据源必须使用DAAL的底层封装库
数据源加速见官方文档(必须使用DAAL自己的库): Data Management Numeric Tables Tensors Data Sources Data Dictionaries Data ...
- Elasticsearch单机下多实例配置
##################### Elasticsearch Configuration Example ##################### index.cache.field.ty ...
- (C#基础)各种加密学习
之前,一直想对这个做一个了解,但是总是坚持不下去,很急躁.最近看了几遍文章,很有感触,于是又来重新开始学习,从最最基础的开始——正所谓“慢就是快”.心态变了,继续吧!上代码! using System ...