问题 G: 数据结构基础18-产生数

题目描述

给出一个整数n(n<=8000)和k个变换规则(k≤15)。规则:
① 1个数字可以变换成另1个数字;
② 规则中,右边的数字不能为零。
例如:n=234,k=2规则为
2 → 5
3 → 6
上面的整数234经过变换后可能产生出的整数为(包括原数)234,534,264,564共4种不同的产生数。
求经过任意次的变换(0次或多次),能产生出多少个不同的整数。仅要求输出不同整数个数。

输入

输入数据如下
n
k
x1 y1
x2 y2
… …
xk yk

输出

格式为一个整数(满足条件的整数个数)。

样例输入 Copy
234
2
2 5
3 6
样例输出 Copy

4

写了一个循环队列吧算是,这个题目说实话我觉得不简单,特别是你要考虑要变化那个位数的时候还是需要思考很多东西的,但是我在想如果这个题用字符串来输入不知道是不是会更好,这样在变化位数的时候是不是代码可以不用那么繁琐,当然我也只是一个想法,是一道循环队列的好题目,记得要判断队列满的这种情况吧。

#include<iostream>
#include<string>
#include<cstdio>
using namespace std;
#define MAX 10005
int rule[20];
int ruleD[20];
int map[10000];
typedef struct queueNode
{
	int data[MAX];
	int front, rear;
	int count;
}qNode;
qNode init()
{
	qNode q;
	q.front = q.rear = 1;
	q.count = 0;
	return q;
}
void enQueue(qNode* q,int k)
{
	if ((q->rear + 1) % MAX == q->front)
	{
		return;
	}
	else
	{
		q->data[q->rear] = k;
		if (q->rear + 1 == MAX)
		{
			q->count++;
		}
		q->rear = (q->rear + 1) % MAX;
	}
}
void find(int n, int k)
{
	qNode q = init();
	enQueue(&q,n);
	map[n] = 1;
	while (q.front < q.rear)
	{
		int temp = q.data[q.front];
		int ai = 1;
		while (temp)
		{
			int t = temp % 10;
			temp = temp / 10;
			for (int i = 1; i <= k; i++)
			{
				if (t == rule[i])
				{
					int sum = q.data[q.front] + ai * (ruleD[i] - rule[i]);
					if (map[sum] == 0)
					{
						map[sum] = 1;
						enQueue(&q, sum);
					}
				}
			}
			ai = ai * 10;
		}
		q.front++;
	}
	int sum = q.rear + q.count * MAX - 1;
	cout << sum << endl;
}
int main()
{
	int n, k;
	cin >> n >> k;
	for (int i = 1; i <= k; i++)
	{
		cin >> rule[i] >> ruleD[i];
	}
	find(n, k);
	return 0;
}
 

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值