[dfs] UVALive 3667 Ruler
题目链接:
option=com_onlinejudge&Itemid=8&page=show_problem&problem=1668
题目意思:
有n个长度须要量。问如何设计尺子刻度,使得每一个长度都在两个刻度之间。在满足刻度数最小的情况下。要求尺子长度越短越好,最開始的刻度为0.
解题思路:
dfs
由于最多的刻度是7,并且可以计算出最小的刻度数。由于当刻度数m确定后。最多可以測量的长度数是固定的C(m,2).
要满足刻度最少且长度最短,能够如果最后一个刻度在长度最长的位置。
然后递增暴搜。
代码:
- //#include<CSpreadSheet.h>
- #include<iostream>
- #include<cmath>
- #include<cstdio>
- #include<sstream>
- #include<cstdlib>
- #include<string>
- #include<string.h>
- #include<cstring>
- #include<algorithm>
- #include<vector>
- #include<map>
- #include<set>
- #include<stack>
- #include<list>
- #include<queue>
- #include<ctime>
- #include<bitset>
- #include<cmath>
- #define eps 1e-6
- #define INF 0x3f3f3f3f
- #define PI acos(-1.0)
- #define ll __int64
- #define LL long long
- #define lson l,m,(rt<<1)
- #define rson m+1,r,(rt<<1)|1
- #define M 1000000007
- //#pragma comment(linker, "/STACK:1024000000,1024000000")
- using namespace std;
- #define Maxn 55
- #define Maxm 1100000
- int hav[Maxm],sa[Maxn],n,ans;
- bool vis[Maxn];
- int dis[Maxn];
- bool dfs(int cur)
- {
- if(cur==ans)
- {
- for(int i=1;i<n;i++) //前n-1个长度都可以測量
- if(!vis[i])
- return false;
- return true;
- }
- for(int i=1;i<cur;i++)
- {
- for(int j=1;j<n;j++)
- {
- if(!vis[j])
- {
- int dd=dis[i]+sa[j];//当前刻度
- if(dd<=dis[cur-1]) //比之前大
- continue;
- if(dd>=sa[n])//要比最大小
- continue;
- dis[cur]=dd;
- queue<int>myq; //记录标记的长度。回溯时返回
- for(int k=1;k<cur;k++) //增加当前刻度后,新增的可以出的长度
- {
- int temp=dis[cur]-dis[k];
- if(hav[temp]&&!vis[hav[temp]])
- {
- vis[hav[temp]]=true;
- myq.push(hav[temp]);
- }
- }
- int la=sa[n]-dis[cur]; //最后一段
- if(hav[la]&&!vis[hav[la]])
- {
- vis[hav[la]]=true;
- myq.push(hav[la]);
- }
- if(dfs(cur+1))
- return true;
- while(!myq.empty())
- {
- la=myq.front();
- myq.pop();
- vis[la]=false;
- }
- }
- }
- }
- return false;
- }
- int main()
- {
- //freopen("in.txt","r",stdin);
- //freopen("out.txt","w",stdout);
- int cas=0;
- while(~scanf("%d",&n)&&n)
- {
- for(int i=1;i<=n;i++)
- scanf("%d",&sa[i]);
- sort(sa+1,sa+n+1);
- n=unique(sa+1,sa+n+1)-sa-1;
- memset(hav,0,sizeof(hav));
- for(int i=1;i<=n;i++)
- hav[sa[i]]=i;
- dis[1]=0;
- ans=2;
- while(ans*(ans-1)/2<n)
- ans++;
- memset(vis,0,sizeof(vis));
- while(!dfs(2))
- ans++;
- printf("Case %d:\n%d\n",++cas,ans);
- printf("%d",dis[1]);
- dis[ans]=sa[n];
- for(int i=2;i<=ans;i++)
- printf(" %d",dis[i]);
- putchar('\n');
- }
- return 0;
- }
[dfs] UVALive 3667 Ruler的更多相关文章
- LA 3667 Ruler 搜索
题意: 给出\(n\)个长度,要设计一个有\(m\)个刻度的刻度尺,刻度尺的刻度从\(0\)开始. 使得任意一个长度都能被该刻度尺度量出来. 首先要使\(m\)最小,在\(m\)最小的前提下尺子的长度 ...
- UVALive 6948 Jokewithpermutation dfs
题目链接:UVALive 6948 Jokewithpermutation 题意:给一串数字序列,没有空格,拆成从1到N的连续数列. dfs. 可以计算出N的值,也可以直接检验当前数组是否合法. # ...
- UVALive - 6436、HYSBZ - 2435 (dfs)
这两道题都是用简单dfs解的,主要是熟悉回溯过程就能做,据说用bfs也能做 道路修建(HYSBZ - 2435) 在 W 星球上有n 个国家.为了各自国家的经济发展,他们决定在各个国家 之间建设双向道 ...
- UVALive 4998 Simple Encryption --DFS
题意: 给出K1,求一个12位数(不含前导0)K2,使得K1^K2 mod (10^12) = K2. 解法: 求不动点问题. 有一个性质: 如果12位数K2满足如上式子的话,那么K2%1,K2%10 ...
- UVALive 4997 ABCD Tiles --DFS
题意: NxN的地图,上面有A颜色的瓷砖以及一些空格点,要用B,C,D颜色去填充这些空格,只能十字形的填充,还要保证共角或共边的格子不能是相同颜色,求一种字典序最小的填充方法,如果不能,输出" ...
- UVALive 6663 Count the Regions --离散化+DFS染色
题意:给你n(n<=50)个矩形(左上角坐标和右下角坐标),问这些矩形总共将平面分成多少个部分.坐标值可能有1e9. 分析:看到n和坐标的范围,容易想到离散化,当时就没想到离散化以后怎么判断区域 ...
- UVALive 6450 Social Advertising DFS解法
题意:一些人有朋友关系,在某个人的社交网站上投放广告可以被所有该人的直接朋友看到,问最小投放多少个广告使给出的人都看到广告.(n<=20) 解法:看到n的范围可以想到用二进制数表示每个人被覆盖与 ...
- UVALive 6257 Chemist's vows --一道题的三种解法(模拟,DFS,DP)
题意:给一个元素周期表的元素符号(114种),再给一个串,问这个串能否有这些元素符号组成(全为小写). 解法1:动态规划 定义:dp[i]表示到 i 这个字符为止,能否有元素周期表里的符号构成. 则有 ...
- UVALive 6884 GREAT + SWERC = PORTO dfs模拟
题目连接: https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show ...
随机推荐
- leetcode486 Predict the Winner
思路: 博弈. 实现: class Solution { public: bool PredictTheWinner(vector<int>& nums) { ][]; int n ...
- LR接口测试---socket
前提条件: 编译:javac TcpServer.java 启动:java TcpServer ============================================ 代码示例: # ...
- 关于FLASK WEB开发8d 数据库迁移的问题
首先, 第一步,要删除data-dev.sqlite这个数据库 第二步,进行下面的重建 暂时的解决办法是: python manage.py shell In [2]: from app import ...
- Pyhton TestCase运行闪退与失败,原因不详。。。
把源码贴上来,希望某位大神可以指点迷津: """Unit test for odbchelper.py This program is part of "Div ...
- Windows离线安装Python第三方库的方法
在window中,离线安装第三方模块, 1.下载第三方库的压缩文件,解压,将解压后的文件放到Python安装目录下的Lib\site_packages中 2. 将Python添加到环境变量里 3.进入 ...
- 【实验级】Docker-Compose搭建单服务器ELK伪集群
本文说明 由于最近在搭ELK的日志系统,为了演示方案搭了个单台服务器的日志系统,就是前一篇文章中所记,其实这些笔记已经整理好久了,一直在解决各种问题就没有发出来.在演示过程中我提到了两个方案,其中之一 ...
- jquery 时间戳转日期
搜了一下发现这个时间戳转时间的代码很好用,附上实践的代码 结果如下 / * * 时间戳转日期 * @param timestamp * @returns {*} */ function timesta ...
- UVA - 808 Bee Breeding (建立坐标系&找规律)
题目: 输入两个格子的编号a和b(a,b≤10000),求最短距离.例如,19和30的距离为5(一条最短路是19-7-6-5-15-30). 思路: 如图建立坐标系,然后看两个点的向量如果位于二四象限 ...
- [LNOI2014]LCA(树链剖分)
BZOJ传送门 Luogu传送门 题目:给你一棵树,给你n个询问,每个询问要求输出$\sum_{i=l}^{r}depth(LCA(i,z))$ 细看看其实没有想象的那么难 大体思路: 1.对于每个询 ...
- Python介绍以及Python 优缺点
Python是先编译成字节码,然后在解释执行的一门语言,而不是单纯的解释型语言 Python应用场景: Web应用开发. 操作系统管理,服务器运维的自动化脚本, 网络爬虫 科学计算 桌面软件 游戏 服 ...