【BZOJ2797】[Poi2012]Squarks 暴力乱搞
【BZOJ2797】[Poi2012]Squarks
Description
设有n个互不相同的正整数{X1,X2,...Xn},任取两个Xi,Xj(i≠j),能算出Xi+Xj。
现在所有取法共n*(n-1)/2个和,要你求出X1,X2,...Xn。
Input
第一行一个正整数n (3<=n<=300)。
第二行n*(n-1)/2个正整数(每个正整数不超过10^8),表示任取两个Xi,Xj(i≠j)算出的n*(n-1)/2个和。
Output
第一行一个正整数k,表示方案数。测试数据保证至少存在一种方案。
下面k行每行给出递增的n个正整数。方案按照{Xi}的最小值从大到小输出。
Sample Input
4
3 5 4 7 6 5
Sample Input 2
4
11 17 12 20 21 15
Sample Output
2
4 7 8 13
3 8 9 12
Sample Output 1
1
1 2 3 4
题解:首先将所有和排序,那么前两个和一定是x1+x2和x1+x3。但是下一个可能是x1+x4或x2+x3。不过容易发现,如果下一个是x2+x3,那么x1,x2,x3就都确定了,我们将这3个数两两相加的和去掉,剩下的最小的和就是x1+x4,再将x4+x(1,2,3)去掉,剩下的就是x1+x5。重复以上过程我们就能得到所有数的值。
所以我们只需要枚举x2+x3何时出现,那么它之前的数一定都是x1+xi,接着我们就能算出前i个数的值,进而得到所有数的值了。在求的时候可以用set维护一下,复杂度就是$O(n^3log_n)$的。
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <set>
using namespace std;
int n,m,sum,ans;
int s[50010],v[310],A[310][310],p[310],k[310],q[310];
multiset<int> S;
multiset<int>::iterator it;
bool cmp(int a,int b)
{
for(int i=1;i<=n;i++) if(A[a][i]!=A[b][i]) return A[a][i]>A[b][i];
return 0;
}
int main()
{
scanf("%d",&n),m=n*(n-1)/2;
int i,j,k,flag;
for(i=1;i<=m;i++) scanf("%d",&s[i]);
sort(s+1,s+m+1);
for(i=3;i<=n;i++)
{
v[1]=(s[1]+s[2]-s[i])/2;
if(v[1]<=0) break;
flag=1;
for(j=2;j<=i&&flag;j++)
{
v[j]=s[j-1]-v[1];
if(v[j]<=v[j-1]) flag=0;
}
if(!flag) continue;
S.clear();
for(j=1;j<=m;j++) S.insert(s[j]);
for(j=1;j<i;j++) for(k=j+1;k<=i&&flag;k++)
{
it=S.find(v[j]+v[k]);
if(it==S.end()) flag=0;
else S.erase(it);
}
for(j=i+1;j<=n&&flag;j++)
{
v[j]=*(S.begin())-v[1];
if(v[j]<=v[j-1]) flag=0;
for(k=1;k<j&&flag;k++)
{
it=S.find(v[j]+v[k]);
if(it==S.end()) flag=0;
else S.erase(it);
}
}
if(!flag) continue;
sum++;
for(j=1;j<=n;j++) A[sum][j]=v[j];
}
for(i=1;i<=sum;i++) p[i]=i;
sort(p+1,p+sum+1,cmp);
for(i=1;i<=sum;i++)
{
for(j=1;j<=n;j++) if(A[p[i]][j]!=A[p[i-1]][j]) break;
if(j<=n) q[++ans]=p[i];
}
printf("%d\n",ans);
for(i=1;i<=ans;i++)
{
for(j=1;j<=n;j++) printf("%d ",A[q[i]][j]);
if(i!=ans) printf("\n");
}
return 0;
}
【BZOJ2797】[Poi2012]Squarks 暴力乱搞的更多相关文章
- VIJOS1476 旅行规划(树形Dp + DFS暴力乱搞)
题意: 给出一个树,树上每一条边的边权为 1,求树上所有最长链的点集并. 细节: 可能存在多条最长链!最长链!最长链!重要的事情说三遍 分析: 方法round 1:暴力乱搞Q A Q,边权为正-> ...
- [BZOJ2797][Poi2012]Squarks
2797: [Poi2012]Squarks Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 211 Solved: 89[Submit][Status ...
- [CSP-S模拟测试]:Cicada拿衣服(暴力+乱搞)
题目传送门(内部题94) 输入格式 第一行两个整数$n,k$,代表衣服的数量和阈值. 接下来一行$n$个数,第$i$个数$a_i$表示每件衣服的愉悦值. 输出格式 输出一行$n$个数,第$i$个数为$ ...
- BZOJ 1491: [NOI2007]社交网络(Floyd+暴力乱搞)
题面: https://www.lydsy.com/JudgeOnline/problem.php?id=1491 题解: 先看数据范围,n<=100..欸可以乱搞了 首先因为小学学过的乘法原理 ...
- Codeforces #254 div1 B. DZY Loves FFT 暴力乱搞
B. DZY Loves FFT 题目连接: http://codeforces.com/contest/444/problem/B Description DZY loves Fast Fourie ...
- Codeforces 34C-Page Numbers(set+vector+暴力乱搞)
C. Page Numbers time limit per test 2 seconds memory limit per test 256 megabytes input standard inp ...
- Codeforces Gym 100203G Good elements 暴力乱搞
原题链接:http://codeforces.com/gym/100203/attachments/download/1702/statements.pdf 题解 考虑暴力的复杂度是O(n^3),所以 ...
- Codeforces 245G Suggested Friends 暴力乱搞
G. Suggested Friends time limit per test 2 seconds memory limit per test 256 megabytes input standar ...
- BZOJ-1050 旅行comf 并查集+乱搞
好久以前codevs上做过的,拿着改了改.. 1050: [HAOI2006]旅行comf Time Limit: 10 Sec Memory Limit: 162 MB Submit: 2194 S ...
随机推荐
- SQL 关于apply的两种形式cross apply 和 outer apply, with cube 、with rollup 和 grouping
1). apply有两种形式: cross apply 和 outer apply先看看语法: <left_table_expression> {cross|outer} apply &l ...
- node定时任务——node-schedule模块使用说明
在实际开发项目中,会遇到很多定时任务的工作.比如:定时导出某些数据.定时发送消息或邮件给用户.定时备份什么类型的文件等等. 一般可以写个定时器,来完成相应的需求,在node.js中自已实现也非常容易, ...
- android BaseAdapter getView 理解
ListView是安卓中很经常使用的一个控件. 安卓设计使用Adapter来对ListView进行管理. 可是系统提供的Adapter无法满足一些复杂的显示情况,这个时候我们就须要使用BaseAdap ...
- django model 多对多保存
- 简单实现Spring中BeanFactory原理
上一篇文章介绍了Java反射机制在Spring IOC中的应用,知道了BeanFactory底层的实现原理. 原理搞懂了,对Spring IOC理解起来也很容易. 先来看看Java代码获取Spring ...
- Android——问题解决之adb not responding;adb不是内部或外部命令;path变量的默认值为多少
adb not responding 恩,这是出现的问题.我们开始来解决它吧! 出现这种问题大多是因为adb端口被占用导致这个问题,所以只要找到占用端口号程序,结束即可!就是这么简单(adb运行端口号 ...
- 脚本中出现“+ $'\r' : command not found
脚本中的部分应该是从doc直接拷过来的,造成回车符“\r”出现问题 通过将脚本内容在linux下拷贝一次,就解决了这个问题!
- js获取字符串的实际长度并截断实际长度
在项目中有这样一个需求,就是一个很长的字符串,需要截断成几组字符串,而这几组字符串里既包含汉字,又包含字母,下面提供了几种方法 1,获取字符串的长度 function getstrlength(str ...
- Python之查询美国护照状态
该程序会每隔至少1秒进行一次护照状态查询 需要修改passportNo变量为自己的护照号码. 另外需要pip install beautifulsoup4 #coding=utf-8 import r ...
- [web开发] php优势 - PHP与ASP.NET的比较
php 优势 - PHP与ASP.NET的比较 如今当提到 Web 开发时,您有许多选择.这些方法中许多都涉及到预处理 — 即,利用特定的标记将代码嵌入到 HTML 页面中,这些标记告诉预处理器,它们 ...