/*
在n个刻度和他们的差里挑不超过7个刻度,0是固定的,最大的刻度肯定是最大值,然后剩下的dfs挑。
*/
#include<bits/stdc++.h> #define inf 0x3f3f3f3f const int maxn=; using namespace std; int n,m,h,maxx,minx,icase,tar_size,a[+],ans[+],tar[+],flag[maxn+]; int b[+]; int fla[maxn+],fla1[maxn+]; int add(int x,int siz){
int cnt=;
for(int i=;i<siz;i++){
if(fla1[abs(a[i]-x)]){
fla[abs(a[i]-x)]++;
if(fla[abs(a[i]-x)]==) cnt++;
}
// if(fla1[x]&&a[i]!=0) {
// fla[x]++;
// if(fla[x]==1) cnt++;
// }
}
return cnt;
} void dele(int x,int siz){
//int cnt=0;
for(int i=;i<siz;i++){
if(fla1[abs(a[i]-x)]){
// if(fla[abs(a[i]-x)]>=1)
fla[abs(a[i]-x)]--;
}
//if(fla1[x]&&a[i]!=0) fla[x]--;
}
//printf("%d\n",cnt);
} void dfs(int now,int res,int index){
//printf("%d\n",res);
if(now>=&&res<tar_size) return ;
if(now<=&&res==tar_size){
//printf("0 ");
//for(int i=0;i<now;i++)
//printf("%d ",a[i]);
//printf("\n");
//set<int>::iterator it=fla.begin();
//for(;it!=fla.end();++it){
// printf("%d ",*it);
//}
// printf("\n");
//printf("%d %d %d\n\n",now,tar_size,res);
if(minx>now) {
minx=now;
for(int i=;i<now;i++) ans[i]=a[i];
}
return ;
}
for(int i=index;i<h;i++){
//a[now]=tar[i];
//if(tar[i]==maxx||tar[i]==0) continue;
int s=add(tar[i],now);
if(!s) {dele(tar[i],now);continue;}
a[now]=tar[i];
//printf("%d %d\n",res+1,fla.size());
//int s=fla.size();
// s=(add(tar[i],now)-s);
//printf("%d\n",s);
//if(!s) continue;
dfs(now+,res+s,i+);
dele(tar[i],now);
}
} int main()
{
while(scanf("%d",&n)!=EOF&&n){
printf("Case %d:\n",++icase);
minx=inf,maxx=,memset(a,,sizeof(a)),memset(tar,,sizeof(tar)),memset(flag,,sizeof(flag));
memset(b,,sizeof(b)),memset(fla,,sizeof(fla)),memset(fla1,,sizeof(fla1));
h=;
int q=;
for(int i=;i<n;i++) {
scanf("%d",&m);
if(!flag[m]) tar[h++]=m,b[q++]=m,flag[m]=,fla1[m]=;
maxx=max(maxx,m);
}
sort(tar,tar+h);
sort(b,b+h);
//for(int i=0;i<h;i++) printf("%d\n",b[i]);
tar_size=h;
for(int i=;i<tar_size;i++){
for(int j=i+;j<tar_size;j++){
if(!flag[tar[j]-tar[i]]) tar[h++]=tar[j]-tar[i],flag[tar[j]-tar[i]]=;
}
}
//printf("%d %d\n",tar_size,h);
sort(tar,tar+h);
//for(int i=0;i<h;i++) printf("%d\n",tar[i]);
//printf("%d\n",fla.size());
a[]=;
fla[]=;
dfs(,,);
sort(ans,ans+minx);
printf("%d\n",minx);
// printf("0");
for(int i=;i<minx;i++) {
//if(ans[i]!=maxx&&ans[i]!=0)
if(!i)
printf("%d",ans[i]);
else printf(" %d",ans[i]);
}
printf("\n");
//printf(" %d\n",maxx);
}
return ;
}

Uva1377的更多相关文章

  1. Win7_Ultimate + VS2010 + openGL_MFC单文档应用开发框架搭建步骤

    Win7_Ultimate + VS2010 + openGL单文档应用开发框架搭建步骤 上一个配置是基于OpenGL的开发工具配置的,下面就是基于Vs2010的MFC单文档应用开发. 通过网上查找资 ...

随机推荐

  1. flash滑杆控制图片横向滚动

    flash滑杆控制图片横向滚动是一款FLASH动画图片左右滚动素材,滑杆控制滚动,效果很酷,带FLASH源文件. 下载:http://www.huiyi8.com/sc/9452.html

  2. LightOJ 1070 Algebraic Problem:矩阵快速幂 + 数学推导

    题目链接:http://lightoj.com/volume_showproblem.php?problem=1070 题意: 给你a+b和ab的值,给定一个n,让你求a^n + b^n的值(MOD ...

  3. 枚举类型的使用方法enum

    一.枚举类型的使用方法 一般的定义方式如下: enum enum_type_name { ENUM_CONST_1, ENUM_CONST_2, ... ENUM_CONST_n } enum_var ...

  4. 3D Flip

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. 如何在Mac下显示Finder中的所有文件

    在Unix下工作,你可能需要处理一些“特殊“文件或文件夹,例如/usr,/bin, etcf,或一些"dot files"(如.bash_profile).但是Linux/Unix ...

  6. Linux Shell: 统计系统中占用Swap 的程序PID和占用大小

    #!/bin/bash  SUM=0 OVERALL=0 for DIR in `find /proc/ -maxdepth 1 -type d -regex "^/proc/[0-9]+& ...

  7. ACM学习历程—HDU 1059 Dividing(dp && 多重背包)

    Description Marsha and Bill own a collection of marbles. They want to split the collection among the ...

  8. Ubuntu 获得超级用户权限

    sudo passwd root 首先要先输入当前用户的密码,再在"输入新的UNIX密码"后面输入你想要设置的 root 密码即可,然后就可以切换到 super user 了: $ ...

  9. Iptables防火墙面试题

    Iptables防火墙面试题 第1章 (一)基础口试题 1.1 详述 iptales 工作流程以及规则过滤顺序? 1.防火墙是一层层过滤的.实际是按照配置规则的顺序从上到下,从前到后进行过滤的. 2. ...

  10. Python中正则匹配使用findall时的注意事项

    在使用正则搜索内容时遇到一个小坑,百度搜了一下,遇到这个坑的还不少,特此记录一下. 比如说有一个字符串  "123@qq.comaaa@163.combbb@126.comasdf111@a ...