HDU 4781 Assignment For Princess 构造
题意:
构造一个\(N(10 \leq N \leq 80)\)个顶点\(M(N+3 \leq M \leq \frac{N^2} {7})\)条边的有向图,要满足如下条件:
- 每条边有一个\([1,M]\)之间的权值,而且每条边的权值都是独一无二的
- 该有向图是强联通的,即任意两点都互相可达
- 图没有自环,而且任意两点之间最多有一条边
- 可以从任意一点出发,经过任意条边,一条边可以走多次,再回到出发点
- 符合上述要求的路径权值之和为3的倍数
分析:
首先我们构造一个长度为\(N\)的环,而且环的权值之和为3的倍数。
构造过程如下:
在顶点\(i\)到\(i+1\)之间连一条长度为\(i\)的有向边,然后在\(N \sim N+2\)之间选一个使得整个环权值和为3的倍数,把这个作为边\((N,1)\)的权值。
这样我们得到的图就满足题目中的要求,但是还剩下\(M-N\)条边没有处理。
对于还没有选用的权值\(w\),选择一对没有连边的顶点\((u,v)\)。
设\(u \rightarrow v\)的路径上的权值和为\(sum\),如果\(w \equiv sum \: (mod 3)\),那么就在这两点之间连边。
这样添边的过程,依然使得原图的性质满足题目要求。
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
using namespace std;
const int maxn = 80 + 10;
const int maxm = 1000;
int G[maxn][maxn], dis[maxn][maxn];
struct Edge
{
int u, v, d;
Edge() {}
Edge(int u, int v, int d):u(u), v(v), d(d) {}
};
int n, m;
int ecnt;
Edge edges[maxm];
bool vis[maxm];
void AddEdge(int u, int v, int d) {
edges[ecnt++] = Edge(u, v, d);
G[u][v] = G[v][u] = true;
}
int main() {
int T; scanf("%d", &T);
for(int kase = 1; kase <= T; kase++) {
scanf("%d%d", &n, &m);
memset(vis, false, sizeof(vis));
memset(G, false, sizeof(G));
ecnt = 0;
for(int i = 1; i < n; i++) {
AddEdge(i, i + 1, i);
vis[i] = true;
}
int sum = (n * (n - 1) / 2) % 3, tmp;
for(int i = n; ; i++) if((i + sum) % 3 == 0) {
vis[i] = true;
AddEdge(n, 1, i);
tmp = i;
break;
}
for(int i = 2; i <= n; i++) {
dis[i-1][i] = (i - 1) % 3;
dis[i][i-1] = (3 - dis[i-1][i]) % 3;
for(int j = i - 2; j >= 1; j--) {
dis[j][i] = (dis[j][i-1] + dis[i-1][i]) % 3;
dis[i][j] = (3 - dis[j][i]) % 3;
}
}
dis[n][1] = tmp % 3;
for(int i = 2; i < n; i++) dis[n][i] = (dis[n][1] + dis[1][i]) % 3;
bool ok = true;
for(int i = n; i <= m; i++) if(!vis[i]) {
bool findit = false;
for(int u = 1; u <= n; u++) {
for(int v = 1; v <= n; v++) if(u != v) {
if(dis[u][v] % 3 == i % 3 && !G[u][v]) {
findit = true;
AddEdge(u, v, i);
break;
}
}
if(findit) break;
}
if(!findit) { ok = false; break; }
}
printf("Case #%d:\n", kase);
if(ok) {
for(int i = 0; i < m; i++)
printf("%d %d %d\n", edges[i].u, edges[i].v, edges[i].d);
}
else printf("-1\n");
}
return 0;
}
HDU 4781 Assignment For Princess 构造的更多相关文章
- hdu 4781 Assignment For Princess (2013ACMICPC 成都站 A)
http://acm.hdu.edu.cn/showproblem.php?pid=4781 由于题目太长,这里就不直接贴了,直接说大意吧. 题目大意:有一个n个点,m条边的有向图,每条边的权值分别为 ...
- hdu4781 Assignment For Princess(构造)
题目链接:hdu4781 Assignment For Princess 题意:n个点m条边,每条有向边的权值分别是1,2,3…m,一个点能到达任意一个点,没有重边和自环,没有任何两条边的权值相同,任 ...
- HDU 2853 Assignment(KM最大匹配好题)
HDU 2853 Assignment 题目链接 题意:如今有N个部队和M个任务(M>=N),每一个部队完毕每一个任务有一点的效率,效率越高越好.可是部队已经安排了一定的计划,这时须要我们尽量用 ...
- HDU 5289 Assignment [优先队列 贪心]
HDU 5289 - Assignment http://acm.hdu.edu.cn/showproblem.php?pid=5289 Tom owns a company and he is th ...
- hdu 2853 Assignment KM算法
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2853 Last year a terrible earthquake attacked Sichuan ...
- HDU 4308 BFS Saving Princess claire_
原题直通车:HDU 4308 Saving Princess claire_ 分析: 两次BFS分别找出‘Y’.‘C’到达最近的‘P’的最小消耗.再算出‘Y’到‘C’的最小消耗,比较出最小值 代码: ...
- HDU - 6313 Hack It(构造)
http://acm.hdu.edu.cn/showproblem.php?pid=6313 题意 让你构造一个矩阵使得里面不存在四个顶点都为1的矩形,并且矩阵里面1的个数要>=85000 分析 ...
- HDU 4685 Prince and Princess 二分图匹配+tarjan
Prince and Princess 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=4685 Description There are n pri ...
- HDU 5289 Assignment rmq
Assignment 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5289 Description Tom owns a company and h ...
随机推荐
- PHP开发环境及搭建
自学PHP中,很多东西都不熟悉,在此做个记录,方便以后再次搭建PHP环境.这篇文章基本按照原文 ThinkPHP5开发环境安装和配置 ,在此感谢该作者 一.实验目的 1.掌握ThinkPHP5(简称 ...
- hubbledotnet 使用笔记
Hubble vs 字符串 <connectionStrings> <add name="Search" connectionString="serve ...
- sql语句优化及后一条减前一条
sql语句优化: 1.表加索引 2.少用like,直接用=所有值 3.where语句把能大量筛查的条件写在前面 4.数据量大时,参与计算的值相同时只取一条 后一条减前一条, select houec, ...
- More than one fragment with the name [spring_web] was found. This is not legal ...
今天在搭建springweb应用环境的时候启动tomcat报错More than one fragment with the name [spring_web] was found. This is ...
- 【Java】JMM内存模型和JVM内存结构
JMM内存模型和JVM内存结构 JAVA内存模型(Java Memory Model) Java内存模型,一般指的是JDK 5 开始使用的新的内存模型,主要由JSR-133: JavaTM Memor ...
- cas实现单点登录原理
1.基于Cookie的单点登录的回顾 基于Cookie的单点登录核心原理: 将用户名密码加密之后存于Cookie中,之后访问网站时在过滤器(filter)中校验用户权限,如果没有权限则从 ...
- 使用github进行代码托管
---恢复内容开始--- 记录下使用github进行个人代码托管,github是公共的代码托管库,可以免费使用,由于是公共的所以大家都可以查看,如果是隐私重要的文件代码可以选择付费变为私有库 1.注册 ...
- 日常-acm-韩信点兵
相传韩信才智过人,从不直接清点自己军队的人数,只要让士兵先后以三人一排,五人一排,七人一排地变换队形,而他每次只看一眼队伍的排尾就知道人数了.输入包含多组数据,每组数据包含三个非负整数a,b,c,表示 ...
- 101个MySQL的调节和优化技巧
MySQL是一个功能强大的开源数据库.随着越来越多的数据库驱动的应用程序,人们一直在推动MySQL发展到它的极限.这里是101条调节和优化MySQL安装的技巧.一些技巧是针对特定的安装环境的,但这些思 ...
- k8s1.13.0二进制部署-Dashboard和coredns(五)
部署UI 下载yaml文件https://github.com/kubernetes/kubernetes [root@k8s-master1 ~]# git clone https://github ...