您的位置:首页 > 其它

codevs 1009 产生数 题解报告

2016-10-16 20:23 363 查看
继续我的刷题路;

题目描述 Description

  给出一个整数 n(n<10^30) 和 k 个变换规则(k<=15)。

  规则:

   一位数可变换成另一个一位数:

   规则的右部不能为零。

  例如:n=234。有规则(k=2):

    2-> 5

    3-> 6

  上面的整数 234 经过变换后可能产生出的整数为(包括原数):

   234

   534

   264

   564

  共 4 种不同的产生数

问题:

  给出一个整数 n 和 k 个规则。

求出:

  经过任意次的变换(0次或多次),能产生出多少个不同整数。

  仅要求输出个数。

输入描述 Input Description

键盘输人,格式为:

  n k

  x1 y1

  x2 y2

  … …

  xn yn

输出描述 Output Description

屏幕输出,格式为:

  一个整数(满足条件的个数)

样例输入 Sample Input

   234 2

   2 5

  3 6

样例输出 Sample Output

4

数据范围及提示 Data Size & Hint

看题意,可以想到组合数的问题,,

不过,,

我不会

2333333333333333333

所以

我写了搜索

因为

只有 0-9 10个数嘛

每个数有一定的k种变化

用f[i]表示所以最后的答案就是每一位上的数 的变化次数之积;

所以只需要DFS处理出每个数可以扩展到的数的个数就好了~~

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<vector>
#include<queue>
#include<map>
#include<set>
#include<stack>
#include<cstdlib>
#include<string>
#include<bitset>
#include<iomanip>
#include<deque>
#define INF 1000000000
#define fi first
#define se second
#define N 100005
#define P 1000000007
#define debug(x) cerr<<#x<<"="<<x<<endl
#define MP(x,y) make_pair(x,y)
using namespace std;
int n,m,f[101],q[10][10],a[1010];
bool v[10];
long long  sum[10];
long long  ans=1;

long long  dfs(long long  x)
{
long long  ansm=1;
for(long long  i=0;i<=9;i++)
{
if(!v[i]&&q[x][i])
{
v[i]=1;
ansm+=dfs(i);
}
}
return ansm;
}
int main()
{
char c;
long long  k=0;
string s;
cin>>s;k=s.size();
for(long long  i=0;i<k;i++)
{
sum[s[i]-'0']++;
a[1+i]=s[i]-'0';
}
cin>>n;
for(long long  i=1;i<=n;i++)
{
long long  w,e;
cin>>w>>e;
q[w][e]=1;
}
for(long long  i=1;i<=k;i++)
{
memset(v,0,sizeof(v));
v[a[i]]=1;
ans*=dfs(a[i]);
}
cout<<ans;
}


相信不难理解,就不写注释了。

4000
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息