1018 - Brush (IV)
Time Limit: 2 second(s) Memory Limit: 32 MB

Mubashwir returned home from the contest and got angry after seeing his room dusty. Who likes to see a dusty room after a brain storming programming contest? After checking a bit he found an old toothbrush in his room. Since the dusts are scattered everywhere, he is a bit confused what to do. So, he called Shakib. Shkib said that, 'Use the brush recursively and clean all the dust, I am cleaning my dust in this way!'

So, Mubashwir got a bit confused, because it's just a tooth brush. So, he will move the brush in a straight line and remove all the dust. Assume that the tooth brush only removes the dusts which lie on the line. But since he has a tooth brush so, he can move the brush in any direction. So, he counts a move as driving the tooth brush in a straight line and removing the dusts in the line.

Now he wants to find the maximum number of moves to remove all dusts. You can assume that dusts are defined as 2D points, and if the brush touches a point, it's cleaned. Since he already had a contest, his head is messy. That's why he wants your help.

Input

Input starts with an integer T (≤ 1000), denoting the number of test cases.

Each case starts with a blank line. The next line contains three integers N (1 ≤ N ≤ 16)N means that there are N dust points. Each of the next N lines will contain two integers xi yi denoting the coordinate of a dust unit. You can assume that (-1000 ≤ xi, yi ≤ 1000) and all points are distinct.

Output

For each case print the case number and the minimum number of moves.

Sample Input

Output for Sample Input

2

3

0 0

1 1

2 2

3

0 0

1 1

2 3

Case 1: 1

Case 2: 2


PROBLEM SETTER: AKM MUBASHWIR ALAM
SPECIAL THANKS: JANE ALAM JAN (DESCRIPTION, SOLUTION, DATASE
题意:给你n个点,然后要你画直线覆盖这些点,问你最少需要几条线可以覆盖所有的点。
思路:状态压缩dp;
两个点决定一条直线,我们先打表将两点确定的直线和在这个直线上的点处理出来,然后 dp[i]表示 在 状态i时最少要 用的 直线 数,dp[de]=min(dp[i]+1,dp[de]);
那么说下状态i表示的是二进制数,那么i中的0为未覆盖的,1为已经覆盖的,那么当i中当且只有一个1时那么 这时直线数应该为1。那么枚举未覆盖 的点用上面的状态转移 方程 就行,最后dp[(1<<n)-1]就为答案。
  1 #include<stdio.h>
2 #include<algorithm>
3 #include<string.h>
4 #include<stdlib.h>
5 #include<queue>
6 #include<iostream>
7 #include<math.h>
8 using namespace std;
9 typedef struct pp
10 {
11 int x;
12 int y;
13 } ss;
14 ss ans[200];
15 int line[20][20];
16 int ck[75550][20];
17 int dp[70000];
18 bool xian(pp a,pp b)
19 {
20 return (a.x*b.y-a.y*b.x)==0?true:false;
21 }
22 int main(void)
23 {
24 int i,j,k;
25 scanf("%d",&k);
26 int c;
27 int n,m;
28 for(i=0; i<(1<<16); i++)
29 {
30 int cc=i;
31 int u=0;
32 int t=1;
33 while(u<16)
34 {
35 if(cc%2==0)
36 {
37 ck[i][t]=u;
38 t++;
39 }
40 cc/=2;
41 u++;
42 }
43 ck[i][0]=t-1;
44 }
45 for(c=1; c<=k; c++)
46 {
47
48 memset(line,0,sizeof(line));
49 fill(dp,dp+65550,100);
50 scanf("%d",&n);
51 int xx;
52 int yy;
53 xx=0;
54 yy=0;
55 for(i=0; i<n; i++)
56 {
57 scanf("%d %d",&ans[i].x,&ans[i].y);
58 if(ans[i].x!=0||ans[i].y!=0)
59 xx=ans[i].x,yy=ans[i].y;
60 }
61 for(i=0; i<n; i++)
62 {
63 for(j=i+1; j<n; j++)
64 {
65 line[i][j]|=(1<<i);
66 line[i][j]|=(1<<j);
67 for(int s=0; s<n; s++)
68 {
69 ss nn;
70 nn.x=ans[i].x-ans[j].x;
71 nn.y=ans[i].y-ans[j].y;
72 ss mm;
73 mm.x=ans[s].x-ans[j].x;
74 mm.y=ans[s].y-ans[j].y;
75 bool ask=xian(nn,mm);
76 if(ask)
77 line[i][j]|=(1<<s);
78 }
79 line[j][i]=line[i][j];
80 }
81 }
82 int ak=(1<<n)-1;
83 dp[0]=0;
84 for(i=0; i<=ak; i++)
85 {
86 int uu=i;
87 int cn=0;
88 cn=ck[i][0];
89 cn-=(16-n);
90 if(n-cn==1)
91 dp[i]=1;
92 if(cn>=2)
93 {
94 int s;
95 for(j=1; j<=1; j++)
96 {
97 for(s=j+1; s<=cn; s++)
98 {
99 int v;
100 int t=line[ck[i][j]][ck[i][s]];
101 int de=i;
102 de|=t;
103 dp[de]=min(dp[de],dp[i]+1);
104 }
105 }
106 }
107 }
108 printf("Case %d: ",c);
109 printf("%d\n",dp[ak]);
110 }
111 return 0;
112 }

1018 - Brush (IV)的更多相关文章

  1. Lightoj 1018 - Brush (IV)

    1018 - Brush (IV)    PDF (English) Statistics Forum Time Limit: 2 second(s) Memory Limit: 32 MB Muba ...

  2. [LightOJ 1018]Brush (IV)[状压DP]

    题目链接:http://lightoj.com/volume_showproblem.php? problem=1018 题意分析:平面上有不超过N个点,如今能够随意方向划直线将它们划去,问:最少要划 ...

  3. Light OJ 1018 - Brush (IV)

    题目大意:     一个二维平面上有N个点,一把刷子,刷一次可以把一条线上的所有点都刷掉.问最少刷多少次,可以把全部的点都刷完 状态压缩DP, 用记忆化搜索来写, 需要有个优化不然会超时. ===== ...

  4. Light oj 1018 - Brush (IV) 状态压缩

    题目大意: 给出n个点的坐标,求至少画多少掉直线才能连接所有点. 题目思路:状态压缩 首先经行预处理,求出所有状态下,那些点不在该状态内 以任意两点为端点求出这条直线的状态 枚举所有状态,找出不在当前 ...

  5. (状压) Brush (IV) (Light OJ 1018)

    http://www.lightoj.com/volume_showproblem.php?problem=1018   Mubashwir returned home from the contes ...

  6. Brush (IV) LightOJ - 1018

    题意:平面上有一些点,每刷一次可以把同一条直线上的点都刷光,问最少几次把所有点刷光. 方法: 显然是一个状态压缩dp.ans[S]表示把S集合中点刷掉的最少次数.最开始想到的方法是如果S中只有一个或两 ...

  7. LightOJ1018 Brush (IV)(状压DP)

    题目大概说一个平面有n个灰尘,可以用一把刷子直直刷过去清理直线上的所有灰尘,问最少要刷几下才能清理完所有灰尘. 首先怎么刷其实是可以确定的,或者说直线有哪些是可以确定的,而最多就有C(n,2)条不一样 ...

  8. lightoj刷题日记

    提高自己的实力, 也为了证明, 开始板刷lightoj,每天题量>=1: 题目的类型会在这边说明,具体见分页博客: SUM=54; 1000 Greetings from LightOJ [简单 ...

  9. dp百题大过关(第一场)

    好吧,这名字真是让我想起了某段被某教科书支配的历史.....各种DP题层出不穷,不过终于做完了orz 虽然各种手糊加乱搞,但还是要总结一下. T1 Monkey Banana Problem    这 ...

随机推荐

  1. 设置administrator账号密码

    设置administrator账号密码: 打开:附件->运行 输入:lusrmgr.msc 在里面的用户里修改administrator密码

  2. ysoserial-CommonsBeanutils1的shiro无依赖链改造

    ysoserial-CommonsBeanutils1的shiro无依赖链改造 一.CB1利用链分析 此条利用链需要配合Commons-Beanutils组件来进行利用,在shiro中是自带此组件的. ...

  3. Set、Map、WeakSet 和 WeakMap 的区别

    先总结: Set1.  成员不能重复2. 只有健值,没有健名,有点类似数组.3. 可以遍历,方法有add, delete,hasweakSet 1. 成员都是对象 2. 成员都是弱引用,随时可以消失. ...

  4. MyBatis Collection小记—— 关联查询、递归查询、多字段关联

    经常会用到mybatis的Collection标签来做级联查询或递归查询,现通过一个伪例来简单的说明一下使用中的关键点: 首先先列出三个表,给出一个场景: 1,角色表 t_role( id,name ...

  5. final&static

    final 1.final修饰类,那么该类不能有子类,那么也就没有子类重写父类的方法,也就没有多态 2.final修饰成员变量,那么成员变量要么显式赋值(用第一种),要么在构造方法中赋值 无论哪一种, ...

  6. implicit declaration of function 'NSFileTypeForHFSTypeCode' is invalid in c99

    问题:implicit declaration of function 'NSFileTypeForHFSTypeCode' is invalid in c99 解决办法: 在出现该问题的函数前后加上 ...

  7. 重量级&轻量级

    重量级 就是说包的大小,还有就是与个人项目的耦合程度,重量级的框架与项目耦合程度大些 代表EJB容器的服务往往是"买一送三",不要都不行 轻量级 就是相对较小的包,当然与项目的耦合 ...

  8. vue实现input输入框的模糊查询

     最近在用uni-app做一个项目,使用的框架还是vue,想了好久才做出来 . HTML代码部分 <input type="text" focus class="s ...

  9. 【JavaWeb】【学习】【过滤器】Filter 的简单应用

    实现效果 在编辑框中输入暗号:如果暗号正确,则跳转到正确页面:如果暗号错误,则跳转到错误界面. [入口界面] [错误界面] [成功界面] [项目结构] JSP文件 本练习有两个jsp页面 页面1:in ...

  10. vivo浏览器的快速开发平台实践-总览篇

    一.什么是快速开发平台 快速开发平台,顾名思义就是可以使得开发更为快速的开发平台,是提高团队开发效率的生产力工具.近一两年,国内很多公司越来越注重研发效能的度量和提升,基于软件开发的特点,覆盖管理和优 ...