Ural_1169_Pairs
此题略坑。。。
思路:把N个点分成m若干个联通子图,然后用m-1个桥把这m个联通子图连接起来即可。
若每个联通子图内部都是完全图也符合题意,但答案却是Wrong Answer,只有把每个联通子图内部当成环来输出才通过,这是本题的一个坑,一个Bug!!!
另外联通子图中点的个数不能等于2(如果不明白请读者认真思考5遍)
第三个要注意的地方就是输出时每个联通子图只能有一个点与外界连接,不能有两个!!!(如果不明白请读者认真思考10遍)
关键在于确定每个联通子图中点的个数,若第i个联通子图中的点个数为a[i],则Σa[i]=N,且Σ(a[i]*(n-a[i]))=2K
即Σa[i]2 =N2 - 2K ,Σa[i]=N
方法有两种:DP 和 搜索
DP:
set<int>s[105];
s[i]是和为i的若干个数的平方和的集合。
dp[105][10005]
若干个数和为i,平方和为j,则dp[i][j]为这些数中最大的那个
s[0].insert(0);
for (int i=0;i<100;++i)
for (set<int>::iterator it=s[i].begin();it!=s[i].end();++it)
for (int j=i?dp[i][*it]:1;j<=100-i;++j)
{
if (j==2) continue;
s[i+j].insert((*it)+j*j);
dp[i+j][(*it)+j*j]=j;
}
搜索:
找出一组数,和为N,平方和为N2 - 2K :
若找到了这样的一组数,返回数的个数,否则返回0
int check(int x,int n,int depth)
{
if (n*n<x) return 0;
for (int i=(depth>1)?a[depth-1]:1;i<=n && x-i*i>=n-i;++i)
{
if (i==2) continue;
a[depth]=i;
if (i==n && i*i==x) return depth;
int y=check(x-i*i,n-i,depth+1);
if (y) return y;
}
return 0;
}
完整代码如下:
DP版:
/*************************************************************************
> File Name: D.cpp
> Author: Chierush
> Mail: qinxiaojie1@gmail.com
> Created Time: 2013年08月02日 星期五 09时05分46秒
************************************************************************/ #include <iostream>
#include <cstring>
#include <cstdlib>
#include <set>
#include <cstdio>
#include <string>
#include <vector>
#include <map>
#include <cmath>
#include <algorithm> #define LL long long
#define LLU unsigned long long using namespace std; int a[101],cnt;
int dp[105][10005]; set<int>s[105]; int main()
{
s[0].insert(0);
for (int i=0;i<100;++i)
for (set<int>::iterator it=s[i].begin();it!=s[i].end();++it)
for (int j=i?dp[i][*it]:1;j<=100-i;++j)
{
if (j==2) continue;
s[i+j].insert((*it)+j*j);
dp[i+j][(*it)+j*j]=j;
}
int n,k;
scanf("%d%d",&n,&k);
int x=n*n-2*k;
if (x<n)
{
puts("-1");
return 0;
}
if (!dp[n][x]) puts("-1");
else
{
int p=n,q=x;
for (;;)
{
if (!p || !q) break;
int o=dp[p][q];
a[cnt++]=o;
p-=o,q-=o*o;
}
sort(a,a+cnt);
for (int i=1;i<cnt;++i) a[i]+=a[i-1];
for (int i=1;i<a[0];++i) printf("%d %d\n",i,i+1);
if (a[0]>1) printf("%d %d\n",1,a[0]);
for (int i=1;i<cnt;++i)
{
printf("%d %d\n",a[i-1],a[i]);
for (int j=a[i-1]+1;j<a[i];++j) printf("%d %d\n",j,j+1);
if (a[i]-a[i-1]>1) printf("%d %d\n",a[i-1]+1,a[i]);
}
}
return 0;
}
搜索版:
/*************************************************************************
> File Name: D.cpp
> Author: Chierush
> Mail: qinxiaojie1@gmail.com
> Created Time: 2013年08月02日 星期五 09时05分46秒
************************************************************************/ #include <iostream>
#include <cstring>
#include <cstdlib>
#include <set>
#include <cstdio>
#include <string>
#include <vector>
#include <map>
#include <cmath>
#include <algorithm> #define LL long long
#define LLU unsigned long long using namespace std; int a[101],cnt; int check(int x,int n,int depth)
{
if (n*n<x) return 0;
for (int i=(depth>1)?a[depth-1]:1;i<=n && x-i*i>=n-i;++i)
{
if (i==2) continue;
a[depth]=i;
if (i==n && i*i==x) return depth;
int y=check(x-i*i,n-i,depth+1);
if (y) return y;
}
return 0;
} int main()
{
int n,k;
scanf("%d%d",&n,&k);
int x=n*n-2*k;
if (x<n)
{
puts("-1");
return 0;
}
int u=check(x,n,1);
if (!u) puts("-1");
else
{
for (int i=2;i<=u;++i) a[i]+=a[i-1];
for (int i=1;i<a[1];++i)
printf("%d %d\n",i,i+1);
if (a[1]>1) printf("%d %d\n",1,a[1]);
for (int i=2;i<=u;++i)
{
printf("%d %d\n",a[i-1],a[i]);
for (int j=a[i-1]+1;j<a[i];++j)
printf("%d %d\n",j,j+1);
if (a[i]-a[i-1]>1) printf("%d %d\n",a[i-1]+1,a[i]);
}
}
return 0;
}
Ural_1169_Pairs的更多相关文章
随机推荐
- Clustering Devices In An Internet Of Things
Clustering devices in an Internet of Things ('IoT'), including: receiving, by a device clustering mo ...
- CUDA页锁定内存(Pinned Memory)
对CUDA架构而言,主机端的内存被分为两种,一种是可分页内存(pageable memroy)和页锁定内存(page-lock或 pinned).可分页内存是由操作系统API malloc()在主机上 ...
- java学习笔记(8)——多线程
进程:是一个程序在其自身的地址空间的一次执行活动. 线程:(区别于进程)线程没有独立的存储空间. 几个概念:时间片 线程 进程 能不能够用多进程代替多线程呢? 两个进程切换时要交换内存空间,而多 ...
- C# WPF 低仿网易云音乐(PC)Banner动画控件
原文:C# WPF 低仿网易云音乐(PC)Banner动画控件 由于技术有限没能做到一模一样的动画,只是粗略地做了一下.动画有点生硬,还有就是没做出网易云音乐的立体感.代码非常简单粗暴,而且我也写有很 ...
- 关于iis里面 .net framework 版本的切换
然而,即便这样还是不够的 在iis上浏览网站会报以下错误: 这是什么原因呢?这是因为应用程序池中没有使用asp.net v4.0 网站程序是用v4.0写的,所以我们要用4.0的程序池版本,当前应用程序 ...
- JDBC数据源DBCP源代码情景分析
在之前的一篇博文从JDBC到commons-dbutils 中,我曾经写到,对于获取数据库连接,有一个解决方案,那就是数据源.业界用到的比较普遍的开源数据源解决方案有很多,DBCP是其中一种,今天,我 ...
- Altera公司高速PCB布线指南
来至Altera公司的高速PCB布线指南,该文档言简意赅,深入浅出,对于日常高速PCB布局布线中经常碰到的一些问题进行了解析.例如:板材的选择,介电常数及损耗因子对高速高频线路的影响,传输线,阻抗控制 ...
- HDU 2845 Beans(dp)
Problem Description Bean-eating is an interesting game, everyone owns an M*N matrix, which is filled ...
- StackLayout
堆栈式地放置内容可以在xaml中完成视图,也可以在cs代码中完成视图 Xamarin的所有视图和布局都是可以 1.在xaml中完成 2.在cs代码中完成视图 (类比WPF) 示例 在cs代码中完成视图 ...
- sql server 查询存储过程指令
Sp_helptext PROCEDUREName 例子 创建存储过程 CREATE PROCEDURE SelectFromBitTable AS BEGIN select pkid,isdelet ...