合法字符串
来源:互联网 发布:淘宝行业数据分析平台 编辑:程序博客网 时间:2024/04/30 11:49
用n个不同的字符(编号1 - n),组成一个字符串,有如下2点要求: 1、对于编号为i 的字符,如果2 * i > n,则该字符可以作为最后一个字符,但如果该字符不是作为最后一个字符的话,则该字符后面可以接任意字符; 2、对于编号为i的字符,如果2 * i <= n,则该字符不可以作为最后一个字符,且该字符后面所紧接着的下一个字符的编号一定要 >= 2 * i。 问有多少长度为M且符合条件的字符串。 例如:N = 2,M = 3。则abb, bab, bbb是符合条件的字符串,剩下的均为不符合条件的字符串。 输入:n,m (2<=n,m<=1000000000); 输出:满足条件的字符串的个数,由于数据很大,输出该数Mod 10^9 + 7的结果。 函数头部 int validstring(int n,int m) { }
#include <iostream>using namespace std;const int BIGGEST = 1000000007;int validstring(int n, int m){int **buf = new int*[2];for (int i = 0; i < 2; i++){buf[i] = new int[n+1];}int halfNum = n/2;int curBuf = 0;for (int i = 1; i <= halfNum; i++){buf[0][i] = 0;}for (int i = halfNum+1; i <= n; i++){buf[0][i] = 1;}int pos = m-2; int oldBuf = 0;long long int result = 0;while (pos >= 0){curBuf = curBuf == 0? 1 : 0;oldBuf = curBuf == 0? 1 : 0;for (int j = 1; j <= n; j++){result = 0;int begin = j <= halfNum? 2*j : 1;for (int x = begin; x <= n; x++){result += buf[oldBuf][x];if (result >= BIGGEST){result %= BIGGEST;}}buf[curBuf][j] = result;}pos--;}result = 0;for (int i = 1; i <= n; i++){result += buf[curBuf][i];if (result >= BIGGEST){result %= BIGGEST;}}for (int i = 0; i < 2; i++){delete []buf[i];}delete []buf;return result;}int main(){cout << validstring(1000, 100) << endl;return 0;}
- 合法字符串
- 合法字符串
- 合法字符串
- 合法字符串
- 庞果网 合法字符串
- 合法字符串题解思路
- 合法字符串 【动态规划】
- C 字符串合法帧
- 字符串的合法验证
- 合法字符串——庞果网
- 京东笔试:合法字符串
- 判断字符串是否是合法的EMail
- 判断字符串是否是合法的EMail
- 判断字符串是否是合法的EMail
- VC判断字符串是否为合法数字
- javascript正则,截取字符串中合法URL
- 判断字符串是否为合法ip
- [iOS]判断字符串是否为合法邮箱地址
- 词法分析进阶(编译原理1-1)
- VS2010 语法错误: 标识符“__RPC__out_xcount_part” 解决方法
- sql server 索引
- SSH原理与运用(一):远程登录
- 评审社区Neutron代码时遇到的两个很有意思的patch ( by quqi99 )
- 合法字符串
- 13-Oracle学习_PL/SQL
- 河床
- 统计一句话或者一个单词出现字母的个数
- 信号量 Linux函数 semget();semctl();semop();
- nyist 510昂贵的聘礼
- struts2学习(12)——上传文件
- hibernate对原生SQL查询执行的控制
- ios 应用剖析