今天是元旦,开篇先祝福你们在新的一年心想事成,工做顺利,开心生活每一天 。算法
看到【英雄会】上出现了微软出的题目:几个bing,题目内容以下:学习
本届大赛由微软必应词典冠名,必应词典(Bing Dictionary)是微软推出的新一代英语学习引擎,里面收录了不少咱们常见的单词,详情请见:http://cn.bing.com/dict/?form=BDVSP4&mkt=zh-CN&setlang=ZH。但现实生活中,咱们也常常能看到一些毫无规则的字符串,致使词典没法正常收录,不过,咱们是否能够从无规则的字符串中提取出正规的单词呢?spa
例若有一个字符串"iinbinbing",截取不一样位置的字符‘b’、‘i’、‘n’、‘g’组合成单词"bing"。若从1开始计数的话,则‘b’ ‘i’ ‘n’ ‘g’这4个字母出现的位置分别为(4,5,6,10) (4,5,9,10),(4,8,9,10)和(7,8,9,10),故总共能够组合成4个单词”bing“。.net
我们的问题是:现给定任意字符串,只包含小写‘b’ ‘i’ ‘n’ ‘g’这4种字母,请问一共能组合成多少个单词bing?code
字符串长度不超过10000,因为结果可能比较大,请输出对10^9 + 7取余数以后的结果。orm
最初的想法:分别记录四个字符出现的位置编号,经过后者字符编号大于前者字符编号条件,循环遍历获得符合条件的次数,但该算法的时间复杂度O(n4),实现绝对能够实现,但确定行不通,改变策略。blog
分析:经过题面分析可知,是从字符串中取‘b’、‘i’、‘n’、‘g’四个字符进行排列组合,从新生成字符串”bing”的过程。但注意的是组合在一块的序列是有必定规律的,序号是逐渐递增的【(4,5,6,10) (4,5,9,10),(4,8,9,10)和(7,8,9,10)】,这就提供了一个先决条件:后者字符必须在前者字符存在的状况下进行计数和组合。算法复杂度为O(n).ci
作法:分别记录b、bi、bin、bing生成的排列次数,后者次数=前者基础次数+后者自身次数(例如:bi次数=b次数+bi自身次数)字符串
以字符串"iinbinbing"为例,对字符串中字符进行遍历:get
① 分别用四个计数器来记录组合
b |
bi |
bin |
bing |
0 |
0 |
0 |
0 |
② 当遍历’i’时,b的计数为0,在没有b存在的基础上,bing是不可能出现的
b |
bi |
bin |
bing |
0 |
0 |
0 |
0 |
③ 当遍历’i’时,b的计数为0,在没有b存在的基础上,bing是不可能出现的
b |
bi |
bin |
bing |
0 |
0 |
0 |
0 |
④ 当遍历’b’时,bing是以b开始的,则b计数为1:
b |
bi |
bin |
bing |
1 |
0 |
0 |
0 |
⑤ 当遍历’i’时,b的计数为1,在有b存在的基础上,bi是能够出现的,则bi计数为1(b计数+bi当前计数):
b |
bi |
bin |
bing |
1 |
1 |
0 |
0 |
⑥ 当遍历’n’时,i的计数为1,在有bi存在的基础上,bin是能够出现的,则bin计数为1(bi计数+bin计数):
b |
bi |
bin |
bing |
1 |
1 |
1 |
0 |
⑦ 当遍历’b’时,则b计数为2:
b |
bi |
bin |
bing |
2 |
1 |
1 |
0 |
⑧ 当遍历’i’时,b的计数为2,在有b存在的基础上,bi可能出现的次数为3(b计数+bi当前计数):
b |
bi |
bin |
bing |
2 |
3 |
1 |
0 |
⑨ 当遍历’n’时,i的计数为2,在有bi存在的基础上,bi可能出现的次数为4(bi计数+bin当前计数):
b |
bi |
bin |
bing |
2 |
3 |
4 |
0 |
⑩ 当遍历’g’时,在有bin存在的基础上,bing可能出现的次数为4(bin计数+bing当前计数):
b |
bi |
bin |
bing |
2 |
3 |
4 |
4 |
这样就获得了bing字符串的组合方式有4种了,代码实现以下:
using System; public class Test { public static int howmany(string s) { int bCount = 0; int biCount = 0; int binCount = 0; int bingCount = 0; for (int index = 0, length = s.Length; index < length; index++) { switch (s[index]) { case 'b': bCount = ++bCount % 1000000007; break; case 'i': biCount = biCount % 1000000007 + bCount; break; case 'n': binCount = binCount % 1000000007 + biCount; break; case 'g': bingCount = bingCount % 1000000007 + binCount; break;
} } return bingCount % 1000000007; }
//start 提示:自动阅卷起始惟一标识,请勿删除或增长。 public static void Main() { Console.WriteLine(howmany("iinbinbing ")); } //end //提示:自动阅卷结束惟一标识,请勿删除或增长。 }