题目描述 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

 #include<iostream>

 using namespace std;

 string n;
int k,can[][]; int main() {
cin>>n>>k;
int x,y;
while(k--) {//k为可变换的数字有多少个
cin>>x>>y,can[x][y]=;//can数组进行标记,即x可以变换为y
}
for(int v=; v<; v++)
for(int j=; j<; j++)
for(int i=; i<; i++)
if(i!=j&&j!=v&&i!=v)//排除x变为x的情况,必须保证让x变为不同的数字
if(can[i][v]==&&can[v][j]==) can[i][j]=;
/*
如果i可以变换成v,并且v还可以变成j的话,那么,i也可以变为j
*/
long long sum=;//进行统计
for(int i=; i<n.length(); i++) {
int n1=n[i]-'',change=;//n1进行转换,将字符串形式的转换为int形式
for(int j=; j<; j++)
if(can[n1][j]==&&n1!=j)//如果当前数字可以进行转换,记录下来,即change++
{
change++;
}
sum*=change;
}
cout<<sum<<endl;//最后输出
return ;
}

最新文章

  1. NPOI操作Excel时使用列头来读取数据的方法
  2. Html5-canvas
  3. CROSS JOIN连接用于生成两张表的笛卡尔集
  4. sql2008 r2 重新启动 失败解决办法
  5. FTP协议详解(转)
  6. Xcode引入外界文件时选Create groups 或 Create folder references的区别
  7. Hadoop中的RPC
  8. (转)iOS 证书、密钥及信任服务
  9. setinterval
  10. Jrebel简单的热部署一个web工程
  11. spring boot admin + spring boot actuator + erueka 微服务监控
  12. [python3.6+opencv] 01 完成读取图片操作
  13. 彻底删除mysql服务(清理注册表)
  14. 《FPGA全程进阶---实战演练》第三十二章 Signal Tap II 应用实例
  15. atof()函数详解
  16. Ubuntu 修改 /etc/resolv.conf 被清空 或重启不生效解决
  17. C++获取和设置时区
  18. iOS 使用Masonry介绍与使用实践:快速上手Autolayout
  19. [Luogu 3128] USACO15DEC Max Flow
  20. 修复TortoiseGit文件夹和文件图标不显示问题的多种解决办法以及重启之后TortoiseGit图标注册表又不见了的解决办法

热门文章

  1. redis缓存穿透00
  2. Python_3day
  3. CVE-2018-19985漏洞学习
  4. Codeforces 1196C. Robot Breakout
  5. JVM--对象访问和OutOfMemoryError异常
  6. centos7安装jdk和tomcat
  7. XAMPP环境搭建及同类推荐
  8. CentOS7使用阿里云的yum源
  9. LeetCode OJ -- 无重复字符的最长子串
  10. PowerDesigner连接 MySQL 生成 ER图