构造

因为题目只要求两位相同,所以可以暴力枚举这两位所有的可能性,方案数为\(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\),所以不会重复)

发现:

\[\sum_{i=1}^{n}{2(_{2}^{s_i})}\ge n*(\frac{t}{n})^2-t
\]

所以总共覆盖的三元组至多有

\[(3n-2)t-2*(n*(\frac{t}{n})^2-t)\ge n^3
\]

这样就可以解出来\(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 题解的更多相关文章

  1. 五、Pandas玩转数据

    Series的简单运算 import numpy as np import pandas as pd s1=pd.Series([1,2,3],index=['A','B','C']) print(s ...

  2. [转]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. 算法教程(3)zz

    First off, we can use our Line-Point Distance code to test for the "BOUNDARY" case. If the ...

  4. TangoAreaDescriptionMetaData区域描述元数据

    TangoAreaDescriptionMetaData com.google.atap.tangoservice Class TangoAreaDescriptionMetaData java.la ...

  5. POJ 3488 &amp; HDU 1915 Arne Saknussemm(模拟)

    题目链接: POJ:http://poj.org/problem? id=3488 HDU:pid=1915">http://acm.hdu.edu.cn/showproblem.ph ...

  6. UVALive 6124 Hexagon Perplexagon 题解

    http://vjudge.net/problem/viewProblem.action?id=37480 East Central Regional Contest Problem C: Hexag ...

  7. LeetCode OJ 题解

    博客搬至blog.csgrandeur.com,cnblogs不再更新. 新的题解会更新在新博客:http://blog.csgrandeur.com/2014/01/15/LeetCode-OJ-S ...

  8. Codeforces Gym 100513D D. Data Center 前缀和 排序

    D. Data Center Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/560/proble ...

  9. 2014年亚洲区域赛北京赛区现场赛A,D,H,I,K题解(hdu5112,5115,5119,5220,5122)

    转载请注明出处: http://www.cnblogs.com/fraud/          ——by fraud 下午在HDU上打了一下今年北京区域赛的重现,过了5题,看来单挑只能拿拿铜牌,呜呜. ...

随机推荐

  1. String方法之fromCharCode()和charCodeAt()

    1.fromCharCode fromCharCode() 可接受一个指定的 Unicode 值,然后返回一个字符串. 语法   我们可以根据 Unicode 来输出 "HELLO" ...

  2. MyEclipse使用总结——Maven项目如何启动运行发布到tomcat中[转]

    前面两篇文章: 新建maven框架的web项目 以及 将原有项目改成maven框架 之后,我们已经有了maven的项目 那么 maven项目到底怎么启动呢 如果我们直接在myeclipse中按以前的启 ...

  3. java基础温习 -- Thread synchronized关键字

    synchronized 基本规则 1. 当一个线程访问“某对象”的“synchronized方法”或者“synchronized代码块”时,其他线程对“该对象”的该“synchronized方法”或 ...

  4. 《DSP using MATLAB》Problem 7.36

    代码: %% ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ %% Output In ...

  5. LinkedList集合 实现栈和队列

    LinkedList集合的底层是链表结构实现的,所以可以模拟栈(先进后出)和队列(先进先出). 方法: addFirst() //添加元素到列表的起始位置 addLast() //添加元素到列表的结束 ...

  6. python学习笔记4.2_正则表达式

    常用正则表达式:http://tool.chinaz.com/regex/ 1.正则表达式:提供了一种在文本中灵活查找或匹配字符串模式的方法.单个表达式通常被称为regex. 2.python的re模 ...

  7. Lua程序设计之数值

    (摘自Lua程序设计) 数值常量 从Lua5.3版本开始Lua语言为数值格式提供了两种选择:被称为integer的64位整形和被称为float的双精度浮点类型(注意,"float" ...

  8. Android开发 Camera2开发_2_预览分辨率或拍照分辨率的计算

    前言 不管在Camera1或者Camera2在适配不同手机/不同使用场景的情况下都需要计算摄像头里提供的分辨率列表中最合适的那一个分辨率.所以在需要大量机型适配的app,是不建议不经过计算直接自定义分 ...

  9. SQL中distinct 和 row_number() over() 的区别及用法

    1 前言 在咱们编写 SQL 语句操作数据库中的数据的时候,有可能会遇到一些不太爽的问题,例如对于同一字段拥有相同名称的记录,我们只需要显示一条,但实际上数据库中可能含有多条拥有相同名称的记录,从而在 ...

  10. 【codeforces 508D】Tanya and Password

    [题目链接]:http://codeforces.com/problemset/problem/508/D [题意] 给你一个字符的所有连续3个的子串; 让你复原出原串; (包含小写.大写字母以及数字 ...