1.codevs1288

题意:对于一个分数a/b(a!=1),将它表示为1/x + 1/y + 1/z ……的形式,x,y,z……互不相同

多解取加数少的,加数相同时,取最小的分数最大的。

思路:经典基础IDA*

搜索无指定界限所以手动规定。因为要求分母尽量小,所以先找最小分母做下界
然后规定层数迭代搜 ans存分母
因为从小到大依次搜,层数加深,第一次找到的一定最优。
估价函数:若扩展到i层时,前i个分数之和为c/d,第i个分数为1/e
因为分母递增,所以接下来至少还需要>(a/b-c/d)/(1/e)个分数,总和才能到a/b.
此估价函数可以估计出最少多少步可以到达解,也就是说限定了层数。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm> #define N 10001
#define ll long long using namespace std; int minn;
ll a,b,deep;
ll ans[N],v[N]; inline ll read()
{
ll x=,f=;char c=getchar();
while(c>''||c<''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
} inline ll gcd(ll x,ll y)
{
if(x<y) x^=y,y^=x,x^=y;
int tmp;
while(y){
tmp=x%y;x=y;y=tmp;
}return x;
} inline bool better(int d)
{
for(int i=d;i>=;i--)
return ans[i]==- || v[i]<ans[i];
return false;
} inline int get(ll x,ll y)//当前下界
{
for(int i=;;++i) if(y<x*i) return i;
} bool IDA(int d,int minn,ll aa,ll bb)
{
if(d==deep)
{
if(bb%aa) return false;//分子必须是1.因为已经约分,不必但心aa不为1
v[d]=bb/aa;
if(better(d)) memcpy(ans,v,sizeof(ll)*(d+));
return true;
}
bool flag=false;
minn=std::max(minn,get(aa,bb));//也算剪枝,minn在不断增大
for(int i=minn;;++i)
{
if(bb*(deep-d+)<=i*aa) break;
//估价函数:因为i在增大,所以如果剩下的deep-d+1个分数全部都是1/i,加起来仍然不超过aa/bb,则无解,需要阔搜索层数
v[d]=i;
ll b2=bb*i,a2=aa*i-bb;//计算aa/bb-1/i
ll g=gcd(a2,b2);
if(IDA(d+,minn+,a2/g,b2/g)) flag=true;
}
return flag;
} int main()
{
a=read();b=read();
minn=get(a,b);
for(deep=;;deep++)
{
memset(ans,-,sizeof ans);//don't forget
if(IDA(,get(a,b),a,b))//get 得到搜索下界
break;
}
for(int i=;i<=deep;++i) printf("%d ",ans[i]);
return ;
} Code

Code

2.codevs 2541

题意:给定n计算m^n的最少运算次数。在运算的每一步,都应该是m的正整数次方

思路:迭代加深

同样的维护已经得到的mi数组
数组的大小对应做了几次运算
加上几个剪枝:
如果mi中最大的<<(deep-k) 都到不了n 搜索失败
生成新的mi的时候 尽量组合数大的 这样也可以减小规模

#include<iostream>
#include<cstdio>
#include<cstring> #define N 101 using namespace std;
int n,a[N<<]; int dfs(int k,int deep)
{
if(a[k]==n) return deep;
if(deep==k) return ;
int maxx=;
for(int i=;i<=k;i++)maxx=max(maxx,a[k]);
if(maxx<<(deep-k)<n)return ;
for(int i=k;i>=;i--)
{
a[k+]=a[k]+a[i];
if(dfs(k+,deep)) return ;
a[k+]=a[k]-a[i];
if(dfs(k+,deep)) return ;
}return ;
} int main()
{
scanf("%d",&n);
if(n==)
{
printf("0\n");
return ;
}
a[]=;
for(int i=;i<=N;i++)
if(dfs(,i))
{
printf("%d\n",i);
return ;
}
return ;
}

Code

3.codevs2495题意:

地毯上的格子有N行N列,每个格子用一个0~5之间的数字代表它的颜色。  水叮当可以随意选择一个0~5之间的颜色,然后轻轻地跳动一步,左上角的格子所在的联通块里的所有格子就会变成她选择的那种颜色。这里连通定义为:两个格子有公共边,并且颜色相同。想知道最少要多少步才能把所有格子的颜色变成一样的。

思路:

左上角的格子所在的联通块里的格子标记为1。左上角联通块周围一圈格子标记为2,
其它格子标记为0。如果某次选择了颜色c,
只需要找出标记为2并且颜色为c的格子,向四周扩展
,并相应地修改v标记,就可以不断扩大标记为1的区域,
最终如果所有格子标记都是1

#include<iostream>
#include<cstring>
#include<cstdio> using namespace std;
int s,n,map[][],mark[][];
int xx[]= {,-,,},yy[]= {,,-,},used[];
bool ans; int get()
{
int t=;
memset(used,,sizeof(used));
for(int i=; i<=n; i++)
for(int j=; j<=n; j++)
if(!used[map[i][j]]&&mark[i][j]!=)
{
used[map[i][j]]=;
t++;
}return t;
} void dfs(int a,int b,int x)
{
mark[a][b]=;
for(int i=; i<; i++)
{
int nowx=a+xx[i],nowy=b+yy[i];
if(nowx<||nowy<||nowx>n||nowy>n||mark[nowx][nowy]==)continue;
mark[nowx][nowy]=;
if(map[nowx][nowy]==x)dfs(nowx,nowy,x);
}
} int fill(int x)
{
int t=;
for(int i=; i<=n; i++)
for(int j=; j<=n; j++)
if(mark[i][j]==&&map[i][j]==x) {t++;dfs(i,j,x);}
return t;
} void search(int k)
{
int v=get();
if(!v)ans=;
if(k+v>s||ans)return;
int temp[][];
for(int i=; i<=; i++)
{
memcpy(temp,mark,sizeof(mark));
if(fill(i))search(k+);
memcpy(mark,temp,sizeof(mark));
}
} int main()
{
while()
{
memset(mark,,sizeof(mark));
scanf("%d",&n);
ans=;
if(n==)break;
for(int i=; i<=n; i++)
for(int j=; j<=n; j++)
scanf("%d",&map[i][j]);
dfs(,,map[][]);
for(s=;;s++)
{
search();
if(ans){printf("%d\n",s); break;}
}
}
return ;
}

Code

迭代,IDA*的更多相关文章

  1. 【Uva 12558】 Egyptian Fractions (HARD version) (迭代加深搜,IDA*)

    IDA* 就是iterative deepening(迭代深搜)+A*(启发式搜索) 启发式搜索就是设计估价函数进行的搜索(可以减很多枝哦~) 这题... 理论上可以回溯,但是解答树非常恐怖,深度没有 ...

  2. 小结:A* & IDA* & 迭代深搜

    概要: 在dfs中,如果答案的深度很小但是却很宽,而且bfs还不一定好做的情况下,我们就综合bfs的优点,结合dfs的思想,进行有限制的dfs.在这里A*.IDA*和迭代深搜都是对dfs的优化,因此放 ...

  3. 埃及分数 迭代加深搜索 IDA*

    迭代加深搜索 IDA* 首先枚举当前选择的分数个数上限maxd,进行迭代加深 之后进行估价,假设当前分数之和为a,目标分数为b,当前考虑分数为1/c,那么如果1/c×(maxd - d)< a ...

  4. 迭代加深 A* IDA* 初探

    并没有有用的东西, 只是用来水的. 今天看搜索,想起来了A*和IDA* 看A*去了.... 啥玩意啊这是,他们代码为啥这么长??.... 看完了,...代码怎么写啊?? .....算了,直接看题吧 找 ...

  5. UVA 11212 Editing a Book [迭代加深搜索IDA*]

    11212 Editing a Book You have n equal-length paragraphs numbered 1 to n. Now you want to arrange the ...

  6. BZOJ1085: [SCOI2005]骑士精神 [迭代加深搜索 IDA*]

    1085: [SCOI2005]骑士精神 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1800  Solved: 984[Submit][Statu ...

  7. 迭代启发式搜索 IDA*

    本章聚集了一些做了的迭代启发式搜索的题目 为什么只打了迭代启发式搜索? 因为它很好打,有些类似迭代的时候加的最优化剪枝 [因为这个最优化剪枝其实就是你算的估价函数了...] BZOJ 1085 骑士精 ...

  8. HDU 1560 DNA sequence (IDA* 迭代加深 搜索)

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=1560 BFS题解:http://www.cnblogs.com/crazyapple/p/321810 ...

  9. 7-10Editing aBook uva11212(迭代加深搜索 IDA*)

    题意:  给出n( 2<=n<=9) 个乱序的数组  要求拍成升序  每次 剪切一段加上粘贴一段算一次  拍成1 2 3 4 ...n即可     求排序次数 典型的状态空间搜索问题   ...

随机推荐

  1. Centos 修改源

    1首先备份原来的配置文件: mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup 2下载对应版本r ...

  2. 【sqli-labs】 less44 POST -Error based -String -Stacked Blind(POST型基于盲注的堆叠字符型注入)

    盲注漏洞,登陆失败和注入失败显示的同一个页面 可以用sleep函数通过延时判断是否闭合引号成功 这个方法有一点不好的地方在于,并不能去控制延时,延时的时间取决于users表中的数据数量和sleep函数 ...

  3. UIResponder详解

    UIResponder Class Reference Managing the Responder Chain 1.- (UIResponder *)nextResponder 返回接收者的下一个相 ...

  4. centOS7创建python虚拟环境

    参考: 非常棒的2篇博客 https://www.centos.bz/2018/05/centos-7-4-%E5%AE%89%E8%A3%85python3%E5%8F%8A%E8%99%9A%E6 ...

  5. [API 开发管理] 分享几个 eoLinker 实用操作技巧

    一键离线导出项目,PDF.WORD等格式任你挑选 举例说明,如果我要将 "示例素材项目" 导出到本地,并且以 PDF 的格式保存. 首先找到该项目所在空间:演示空间,在左边一级菜单 ...

  6. [工具]iostat

    本文主要分析了Linux的iostat命令的源码 iostat源码共563行,应该算是Linux系统命令代码比较少的了.源代码中主要涉及到如下几个Linux的内核文件: 1./proc/disksta ...

  7. codevs 1160 蛇形矩阵

    1160 蛇形矩阵 传送门  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 白银 Silver 题解       题目描述 Description 小明玩一个数字游戏,取个n行 ...

  8. HDU-1864&&HDU-2602(01背包问题)

    DP-01背包问题例题 输入处理有点恶心人,不过处理完后就是简单的DP了 从头开始dp[i]表示从0开始到i的最优结果,最后从都边里dp数组,求得最大的报销额. 对于每个i都要从头维护最优结果.(二刷 ...

  9. JS布尔值(Boolean)转换规则

    原文作者: louis 原文链接: http://louiszhai.github.io/2015/12/11/js.boolean/ 语法 众所周知, JavaScript有五个基本的值类型:num ...

  10. windows和linux下 Python2,Python3 的环境及安装

    目录 windows和linux下 Python2,Python3 的环境及安装 window下安装 一. 手动安装 二. pip安装 linux下 安装 更新Python 笔者有话 windows和 ...