P5562 [Celeste-B]Center of the Earth 题解
构造
因为题目只要求两位相同,所以可以暴力枚举这两位所有的可能性,方案数为\(O(n^2)\)。
但是,这么做是显然不优的,因为完全没有用到第三位。
观察题目条件:n为偶数。
就想一想能不能奇数偶数分开来做呢?
注意到一共有三位,总共放到奇偶两个抽屉中,必有一个抽屉有两个位,即存在两位同奇偶。
我们就想办法枚举到这两位同奇偶的数对。
一个有序三元组\((a,b,c)\)可以覆盖三个有序的二元组\((a,b,?),(?,b,c),(a,?,c)\)
这样的有序二元组取值为\([1,n]\)时共有\(3n^2\)
由于我们分奇偶讨论,所以每种有\(\frac{3}{4}n^2\)个,总计\(\frac{3}{2}n^2\)个
如果两两不相同,那么一次性可以排除三个,总共需要排除\(\frac{n^2}{2}\)次。
可以很容易构造出两两不同的方案,详情见代码。
此时我们感觉答案已经很优了。
证明
设你使用了猜了\(t\)个答案
所有答案为\((a_i,b_i,c_i)\)这样的三元组
按照\(a_i\)划分为\(n\)个集合\(S_i\),\(S_i\)中每个三元组的\(a\)等于\(i\)
设\(s_i=|S_i|\)
显然这些答案要求覆盖所有的\(n^3\)个三元组
一个答案\((a,b,c)\)可以覆盖所有形如\((a,b,?),(?,b,c),(a,?,c)\)的三元组,不难发现有\(3n-2\)个
考察每个集合内部重复覆盖的三元组
如:
\((a,b,c)\)和\((a,d,e)\)共同覆盖了\((a,b,e),(a,d,c)\)两个三元组
\((a,b,c)\)和\((d,b,e)\)共同覆盖了\((d,b,c),(a,b,e)\)两个三元组
\((a,b,c)\)和\((a,b,d)\)共同覆盖了\((a,b,?)\)共\(n\)个三元组(只考虑\(n\ge4\)的情况)
所以同一集合内的两个三元组至少重复覆盖了2个三元组
按\(a\)和按\(b\)分类算两次并不会使答案变得比实际更小。(只有前两项相同的三元组才会重复减去,而需要减去的\(n\ge2+2\),所以不会重复)
发现:
\]
所以总共覆盖的三元组至多有
\]
这样就可以解出来\(t\ge\frac{n^2}{2}\)了
代码
#include<bits/stdc++.h>
using namespace std;
int n,k;
int main(){
scanf("%d",&n);
k=n/2;
printf("%lld\n",1ll*n*n/2);
for(int i=1;i<=k;i++)
for(int j=1;j<=k;j++)
printf("%d %d %d\n",2*i-1,2*j-1,2*((j+i)%k+1)-1);
for(int i=1;i<=k;i++)
for(int j=1;j<=k;j++)
printf("%d %d %d\n",2*i,2*j,2*((i+j)%k+1));
}
P5562 [Celeste-B]Center of the Earth 题解的更多相关文章
- 五、Pandas玩转数据
Series的简单运算 import numpy as np import pandas as pd s1=pd.Series([1,2,3],index=['A','B','C']) print(s ...
- [转]DCM Tutorial – An Introduction to Orientation Kinematics
原地址http://www.starlino.com/dcm_tutorial.html Introduction This article is a continuation of my IMU G ...
- 算法教程(3)zz
First off, we can use our Line-Point Distance code to test for the "BOUNDARY" case. If the ...
- TangoAreaDescriptionMetaData区域描述元数据
TangoAreaDescriptionMetaData com.google.atap.tangoservice Class TangoAreaDescriptionMetaData java.la ...
- POJ 3488 & HDU 1915 Arne Saknussemm(模拟)
题目链接: POJ:http://poj.org/problem? id=3488 HDU:pid=1915">http://acm.hdu.edu.cn/showproblem.ph ...
- UVALive 6124 Hexagon Perplexagon 题解
http://vjudge.net/problem/viewProblem.action?id=37480 East Central Regional Contest Problem C: Hexag ...
- LeetCode OJ 题解
博客搬至blog.csgrandeur.com,cnblogs不再更新. 新的题解会更新在新博客:http://blog.csgrandeur.com/2014/01/15/LeetCode-OJ-S ...
- Codeforces Gym 100513D D. Data Center 前缀和 排序
D. Data Center Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/560/proble ...
- 2014年亚洲区域赛北京赛区现场赛A,D,H,I,K题解(hdu5112,5115,5119,5220,5122)
转载请注明出处: http://www.cnblogs.com/fraud/ ——by fraud 下午在HDU上打了一下今年北京区域赛的重现,过了5题,看来单挑只能拿拿铜牌,呜呜. ...
随机推荐
- centos7 搭建 php7 + nginx (1)
前言 曾今,写过几篇类似的文章,但是发现几个月后,自己回头再看的时候,有种支离破碎的感觉.自己写的并不全,所以今天打算写一篇比较详细的文档.争取下次环境的减的时候,只需要拷贝复制粘贴即可完成环境搭建. ...
- java 调用区块链 发布和调用智能合约
java连接区块链 很简单 ,调用智能合约要麻烦一些. 先说连接 区块链查询数据. 1 maven 项目导入 web3j 的依赖. <dependency> <groupId> ...
- PAT甲级——A1092 To Buy or Not to Buy【20】
Eva would like to make a string of beads with her favorite colors so she went to a small shop to buy ...
- Delphi的日志库
1. 安装 Log4D下载: 官网地址 LoggerPro下载 GitHub地址 特点: log4d简单易用.性能稳定 LoggerPro貌似功能很强大,只是没有详细的文档,懒得翻源码 安装步骤 Lo ...
- Django项目: 4.用户登录登出功能
用户登录登出功能 一.功能需求分析 1. 登录退出功能分析 流程图 功能 登录页面 登录功能 退出功能 二.登录页面 1. 接口设计 接口说明 类目 说明 请求方法 GET url定义 /user/l ...
- 3926: [Zjoi2015]诸神眷顾的幻想乡
传送门 一个广义后缀自动机模板. //Achen #include<algorithm> #include<iostream> #include<cstring> ...
- 深入浅出 Java Concurrency (10): 锁机制 part 5 闭锁 (CountDownLatch)[转]
此小节介绍几个与锁有关的有用工具. 闭锁(Latch) 闭锁(Latch):一种同步方法,可以延迟线程的进度直到线程到达某个终点状态.通俗的讲就是,一个闭锁相当于一扇大门,在大门打开之前所有线程都被阻 ...
- jeecms添加站点
Step1:点击[站点管理],然后点击[添加站点]. Step2:按照下图填写,注意[路径]这一栏!!这里我随便写了个[aaa]. Step3:这个时候在本地部署的tomcat的模板路径:tomcat ...
- mysql中的字符集和校对规则(mysql校对集)
1.简要说明介绍 字符集和校对规则 字符集是一套符号和编码.校对规则是在字符集内用于比较字符的一套规则. MySql在collation提供较强的支持,oracel在这方面没查到相应的资料. 不同字符 ...
- Action详解
简介 Action 是用于处理请求操作的,它是由 StrutsPrepareAndExecuteFilter 分发过来的. 在 Struts2 框架中,Action 是框架的核心类,被称为业务逻辑控制 ...