问题描述:
关于整数 i 的变换 f 和 g 定义如下:f(i)=3i;g(i)=i/2(下取整)。
试设计一个算法,对于给定的 2 个整数 n 和 m,用最少的 f 和 g 变换次数将 n 变换为 m。例如,可以将整数 15 用 4 次变换将
它变换为整数 4:4=gfgg(15)。
要求:对任意给定的整数 n 和 m,计算将整数 n 变换为整数 m 所需要的最少变换次数。
输入(Input):
2 个正整数 n 和 m。
输出(Output):
(1)最少变换次数;
(2)相应的变换序列。
示例(Sample):
输入(Input):
15 4
输出(Output):
4
gfgg
#include <iostream>
using namespace std;
int k = 1;
int c = 0;
char a[100] = {'\0'};
int SelectFun(const int n, const int m, int s) //选择函数
{
if(s == 0){
return 3 * n;
}
else{
return n / 2;
}
}
bool DeptSearch(int Dept, const int n, const int m)//深搜
{
int num;
if(Dept > k) return false;
num = n;
for(int i = 0; i < 2; i++)
{
num = SelectFun(n, m, i);
if(num == m || DeptSearch(Dept + 1,num,m)){
if(i == 0){
a[c] = 'f';
}
else{
a[c] = 'g';
}
c ++;
return true;
}
}
return false;
}
int main()
{
int m, n, Dept = 1;
cin >> m >> n;
k = 1;
while( !DeptSearch(1, m, n) )
{
k ++;
}
cout << k << endl;
int i = 0;
for(i = 0; i < c; i ++){
cout << a[i];
}
return 0;
}
对于m无论如何变换都不能变为n的情况,可以自己加一个判断条件,比如深度达1000终止,因为作业没有要求这个部分,所以没写(就是懒)~