标题:floor函数的反函数--回溯
只看楼主
diaoxue
Rank: 1
等 级:新手上路
帖 子:142
专家分:0
注 册:2007-6-1
 问题点数:0 回复次数:0 
floor函数的反函数--回溯
/*f=3*i,g=|_i/2_|(下取整函数),*
*经过n此运算,将q转换为p*      *
*auther:diaoxue              */
#include <iostream>
using namespace std;
int n=4,i=0;
float p=4.0;
float q=15.0;
int x[4]={0};
void BackT(int i)
{
 if(i>=n && q==p)
 {
  for(int j=0;j<n;j++)
   cout<<x[j]<<"-";
  cout<<endl;
  cout<<"END!"<<endl;
 }
 if(q<p)
 {
  x[i]=1;
  q=3*q;
  BackT(i+1);
  q/=3;
  x[i]=0;
 }
 if(q>p)
 {
  q=(int)(q/2);//可以用floor函数
  BackT(i+1);
  q=2*q+1;//怎么得到原来的值,难道只能用一个变量保存q值吗
 }
}
int main()
{
 BackT(i);
 return 0;
}
搜索更多相关主题的帖子: floor 函数 回溯 
2007-12-08 15:13



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-191167-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.216641 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved