| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 985 人关注过本帖
标题: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
快速回复:floor函数的反函数--回溯
数据加载中...
 
   



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

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