Codeforces Round #597 (Div. 2) C dp


设dpi为前面长度为i的字符串的所有可能组合,如果 s[i]==s[i-1]并且s[i]∈{u,n}
那么dp[i]=dp[i-1]+dp[i-2]否则dp[i]=dp[i-1],最后结果就是dp[s[i].length]


#include<bits/stdc++.h>
#include<string.h>
using namespace std;
#define rep(i,j,k) for(LL i=(j); i<(k); ++i)
#define pb push_back
#define PII pair<LL,LL>
#define PLL pair<long long, long long>
#define ini(a,j) memset(a,j,sizeof a)
#define rrep(i,j,k) for(LL i=j; i>=k; --i)
#define fi first
#define se second
#define LL long long
#define beg begin()
#define ed end()
#define all(x) x.begin(),x.end()
const LL mod= 1e9+7;
const unsigned int N = 1e5+10;
string s;
LL dp[N];
int main(int argc, char const *argv[])
{
	// #define DEBUG
    	#ifdef DEBUG
		freopen("1.dat","r",stdin);
		freopen("ans.dat","w",stdout);
	#endif
	LL _=1;
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	// cin>>_;
	while(_--){
		cin>>s;
		if(count(all(s),'m')!=0||count(all(s),'w')!=0)
			cout<<0<<endl;
		else{
			int n = s.length();
			dp[0]=1;
			dp[1]=1;
			// for(int i=)
			rep(i,1,n)
			{
				if(s[i]=='n'&&s[i-1]=='n')
					dp[i+1]=dp[i]+dp[i-1];
				else if(s[i]=='u'&&s[i-1]=='u')
					dp[i+1]=dp[i]+dp[i-1];
				else
					dp[i+1]=dp[i];
				dp[i+1] %= mod;
			}
			cout<<dp[n]%mod<<endl;
		}
	}
	return 0;
}
posted @ 2020-05-27 19:37  CrosseaLL  阅读(98)  评论(0编辑  收藏  举报