NOIP 2002 产生数
洛谷 P1037 产生数
https://www.luogu.org/problemnew/show/P1037
JDOJ 1298: [NOIP2002]产生数 T3
https://neooj.com:8082/oldoj/problem.php?id=1298
题目描述
给出一个整数n(n<10^{30})n(n<1030)和kk个变换规则(k \le 15)(k≤15)。
规则:
一位数可变换成另一个一位数:
规则的右部不能为零。
例如:n=234n=234。有规则(k=2k=2):
22->55
33->66
上面的整数234234经过变换后可能产生出的整数为(包括原数):
234234
534534
264264
564564
共44 种不同的产生数
问题:
给出一个整数 nn 和kk 个规则。
求出:
经过任意次的变换(00次或多次),能产生出多少个不同整数。
仅要求输出个数。
输入输出格式
输入格式:
键盘输入,格式为:
n knk
x_1 y_1x1y1
x_2 y_2x2y2
... ...
x_n y_nxnyn
输出格式:
屏幕输出,格式为:
11个整数(满足条件的个数):
输入输出样例
234 2
2 5
3 6
4
#include<cstdio>
#include<cstring>
int z,ans=,k;
int a[],b[];
int t[];
bool v[];
char s[];
void dfs(int e)
{
for(int i=;i<=k;i++)
{
if(!v[b[i]]&&a[i]==e)
{
z++;
v[b[i]]=true;
dfs(b[i]);
}
}
}
int main()
{
scanf("%s",s);
scanf("%d",&k);
for(int i=;i<=k;i++)
scanf("%d%d",&a[i],&b[i]);
int l=strlen(s);
for(int i=;i<l;i++)
{
z=;
int c=s[i]=s[i]-'';
memset(v,false,sizeof(v));
v[c]=true;
dfs(c);
t[i]=+z;
}
int k[][];
memset(k,,sizeof(k));
for(int i=l;i>=;i--)
t[i]=t[i-];
k[][]=;
k[][]=;
k[][]=t[];
for(int i=;i<=l;i++)
{
k[i][]=k[i-][];
int x=;
for(int j=;j<=k[i][];j++)
{
k[i][j]=k[i-][j]*t[i]+x;
x=k[i][j]/;
if(k[i][j]>=)
k[i][j]%=;
}
if(x)
{
k[i][]++;
k[i][k[i][]]=x;
}
}
for(int i=k[l][];i>=;i--)
printf("%d",k[l][i]);
}
NOIP 2002 产生数的更多相关文章
- NOIP 2002 选数
洛谷 P1036 选数 洛谷传送门 JDOJ 1297: [NOIP2002]选数 T2 JDOJ传送门 Description 已知 n 个整数 x1,x2,-,xn,以及一个整数 k(k< ...
- NOIP 2002提高组 选数 dfs/暴力
1008 选数 2002年NOIP全国联赛普及组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 已知 n 个整数 x1,x2,…, ...
- [NOIP 2002普及组]产生数(floyd+高精度)
https://www.luogu.org/problem/P1037 题目描述 给出一个整数 n(n<1030) 和 k 个变换规则(k<=15). 规则: 一位数可变换成另一个一位数: ...
- NOIP 2002过河卒 Label:dp
题目描述 如图,A 点有一个过河卒,需要走到目标 B 点.卒行走规则:可以向下.或者向右.同时在棋盘上的任一点有一个对方的马(如上图的C点),该马所在的点和所有跳跃一步可达的点称为对方马的控制点.例如 ...
- NOIP 2002 提高组 字串变换
题目描述 已知有两个字串 A, B 及一组字串变换的规则(至多6个规则): A1 -> B1 A2 -> B2 规则的含义为:在 A$中的子串 A1 可以变换为 B1.A2 可以变换为 B ...
- 2018.10.14 NOIP训练 猜数游戏(决策单调性优化dp)
传送门 一道神奇的dp题. 这题的决策单调性优化跟普通的不同. 首先发现这道题只跟r−lr-lr−l有关. 然后定义状态f[i][j]f[i][j]f[i][j]表示猜范围为[L,L+i−1][L,L ...
- 2018.07.08 NOIP模拟 好数(线段树)
好数 题目背景 SOURCE:NOIP2016-AHSDFZ T3 题目描述 我们定义一个非负整数是"好数",当且仅当它符合以下条件之一: 1. 这个数是 0 或 1 . 2. 所 ...
- 过河卒 NOIp 2002 dp
题目描述 棋盘上AAA点有一个过河卒,需要走到目标BBB点.卒行走的规则:可以向下.或者向右.同时在棋盘上CCC点有一个对方的马,该马所在的点和所有跳跃一步可达的点称为对方马的控制点.因此称之为“马拦 ...
- [ NOIP 2002 ] TG
\(\\\) \(\#A\) 均分纸牌 有\(N\)堆纸牌,每堆有若干张,但纸牌总数必为\(N\)的倍数.可以在任一堆上取若干张纸牌,然后移动给其左右任意一侧的纸牌堆,求将所有的牌堆牌数都变为平均值最 ...
随机推荐
- SQL Server 删除数据库
1. 图形化界面删除 在所需要删除的数据库上右击,然后删除.注意如果这个数据库有应用或者用户连接,请勾选[关闭现有连接],否则无法删除. 2. DROP DATABASE删除数据库 drop data ...
- 怎样把ndarray转换为PyQt中的QPixmap
找不到文档,只在网上找到一些语焉不详,执行错误的代码,鼓捣了一个晚上,研(luan)究(gao)成功 def img2pixmap(self, image): Y, X = image.shape[: ...
- 【2019.8.12 慈溪模拟赛 T2】汪哥图(wang)(前缀和)
森林 考虑到题目中给出条件两点间至多只有一条路径. 就可以发现,这是一个森林. 而森林有一个很有用的性质. 考虑对于一棵树,点数-边数=\(1\). 因此对于一个森林,点数-边数=连通块个数. 所以, ...
- 探索 ASP.Net Core 3.0系列三:ASP.Net Core 3.0中的Service provider validation
前言:在本文中,我将描述ASP.NET Core 3.0中新的“validate on build”功能. 这可以用来检测您的DI service provider是否配置错误. 具体而言,该功能可检 ...
- python 中in 的 用法
1. 作用为 成员运算符 在字符串内操作,如果字符串包含相关字符 则返回True,如果不包含则返回False 当然处理不单单是只有单个字符,多个连续的字符也是可以处理的 # 单个字符 a= ...
- HTML+css基础 css选择器 选择器的权重
css选择器 选择器的权重 在css中,哪个选择器的权重高,就走谁的样式 标签选择器的权重是1 class选择器的权重是10 Id选择器的权重是100 行间样式的权重是1000 带有关键字 !imp ...
- 【Zabbix】zabora监控Oracle数据库
zabora监控Oracle数据库 它作为一个开源项目,通过shell脚本有效的监控Oracle基础指标.本文档旨在通过实战,在Zabbix 3.0版本之下,监控生产环境下的多台Oracle数据库. ...
- appstore-react v2.0—redux-actions和redux-saga的应用
开发文档 https://redux-saga.js.org/ https://redux-saga-in-chinese.js.org/ https://redux-actions.js.org/ ...
- FreeBSD Set a Default Route / Gateway
Task: View / Display FreeBSD Routing Table Use netstat command with -r option:$ netstat -r$ netstat ...
- Unable to parse composition
Unable to parse composition When i tried to load gif to my project suddenly return me error: Java.La ...