EOJ Monthly 2018.7
准备继续大学acm啦
又要开始愉快的码码码啦
第一次在华东师大OJ上面做题
看来EOJ上的积分体质是假的,我怎么一把上红???
A.数三角形
神tm的防AK题放在A,出题人很不友好啊...
先写了个暴力,算出了1-5的结果,然后在OEIS上面搜了一下(雾)
\(a(n) = ((n - 1)^2*n^2*(n + 1)^2)/6 - 2*Sum(Sum((n - k + 1)*(n - l + 1)*gcd(k - 1, l - 1), k, 2, n), l, 2, n)\).
拍了一下,似乎没什么问题,但是复杂度是\(O(n^2)\),看了一下,似乎可以用莫比乌斯反演来枚举gcd,但好像已经太久没写,意识模糊,不会了...
先弃着...
B.锐角三角形
签到题
对于偶数\((0,0)\)\((0,2)\)\((n/2,1)\)即可
对于奇数\((0,1)\)\((1,0)\)\((n/2+1,n/2+1)\)即可
LL n;
int main()
{
read(n);
if (n<=2){puts("No");return 0;}
if (n%2==0)
{
puts("Yes");
puts("0 0");puts("0 2");
print(n/2);puts(" 1");
}
else
{
puts("Yes");
puts("0 1");puts("1 0");
print(n/2+1);putchar(' ');print(n/2+1);puts("");
}
return 0;
}
C.大鱼吃小鱼
D.数蝌蚪
考虑枚举首项,显然首项\(∈[0,10000]\),不然代价显然是非常大的
可以脑补一下,很显然地,对于首项而言,代价是一个凹函数
可以考虑用三分来解决,三分+暴力计算结果即可
int n;
LL m,a[300010];
LL calc(LL x)
{
LL res=0,k=x;
for (int i=1;i<=n;i++)
res+=abs(a[i]-k),k+=m;
return res;
}
int main()
{
read(n);read(m);
for (int i=1;i<=n;i++)
read(a[i]);
int l=0,r=1000000,mid1,mid2,ans;LL x,y;
while (l<=r)
{
if (r-l<=10) break;
mid1=l+(r-l)/3;mid2=l+(r-l)/3*2;
x=calc(mid1),y=calc(mid2);
if (x<y) r=mid2;
else l=mid1;
}
LL res=calc(l);
for (int i=l+1;i<=r;i++)
res=min(res,calc(i));
print(res),puts("");
return 0;
}
不过似乎不用这么麻烦?看看出题人的题解。
令 bi=ai−ki (0-indexed),然后就转化为把所有数变为相同的非负整数至少要操作多少步。直接取中位数即可(注意要特判小于 0 的情况),当然也可以排个序前缀和维护一下。
E.对称与科学美
直接随机化?
考虑对每一个不同数,随机分配一个随机数,然后的问题就是区间xor为0的个数
区间xor为0的情况,我们可以前缀和,然后排个序解决,当然也可以用map来存贮一下,然后对map遍历即可
但是对于随机分配的随机数,似乎数据比较坑,一开始一直Wa at test14,直到不断的把随机产生数不断地扩大,才勉强AC,雾....Wa了8次,有点惨烈
map<int,LL> a;
map<LL,int> c;
int n;
LL b[300010];
int main()
{
read(n);
srand(time(NULL));
int x;LL y;
for (int i=1;i<=n;i++)
{
read(x);
if (a.count(x)) y=a[x];
else{y=1LL;for (int j=1;j<=10;j++) y=y*rand();a[x]=y;}
b[i]=b[i-1]^y;
}
for (int i=0;i<=n;i++) c[b[i]]++;
LL ans=0;
for (map<LL,int>::iterator it=c.begin();it!=c.end();it++)
ans+=1ll*(it->second)*(it->second-1)/2ll;
print(ans),puts("");
return 0;
}
EOJ Monthly 2018.7的更多相关文章
- EOJ Monthly 2018.8 D. Delivery Service-树上差分(边权/边覆盖)(边权转点权)(模板题)
D. Delivery Service 单测试点时限: 2.5 秒 内存限制: 512 MB EOJ Delivery Service Company handles a massive amount ...
- EOJ Monthly 2018.4
A. ultmaster 的小迷妹们 Time limit per test: 2.0 seconds Memory limit: 256 megabytes ultmaster 男神和他的小迷妹们准 ...
- EOJ Monthly 2018.4 (E.小迷妹在哪儿(贪心&排序&背包)
ultmaster 男神和小迷妹们玩起了捉迷藏的游戏. 小迷妹们都希望自己被 ultmaster 男神发现,因此她们都把自己位置告诉了 ultmaster 男神,因此 ultmaster 男神知道了自 ...
- [EOJ Monthly 2018.10][C. 痛苦的 01 矩阵]
题目链接:C. 痛苦的 01 矩阵 题目大意:原题说的很清楚了,不需要简化_(:з」∠)_ 题解:设\(r_i\)为第\(i\)行中0的个数,\(c_j\)为第\(j\)列中0的个数,\(f_{i,j ...
- EOJ Monthly 2018.11 D. 猜价格
猜价格 分两种情况讨论: k≤n,先猜至多 k 次 1,由于回答 <1 肯定是假的,所以可以把剩余系下是哪次错试出来,然后用至多 n 次搞定. k>n,每个数都猜两次,如果两次结果不一样, ...
- 【EOJ Monthly 2018.7】【D数蝌蚪】
https://acm.ecnu.edu.cn/contest/92/problem/D/ D. 数蝌蚪 Time limit per test: 2.0 seconds Memory limit: ...
- EOJ Monthly 2018.7 B.锐角三角形(数学几何+思维)
描述 是否存在面积为S/2的整点锐角三角形?存在输出Yes并输出三个整点坐标,否则输出No. 注意如果存在输出的坐标必须在long long范围内. Input 第一行一个整数S(1<=S< ...
- EOJ Monthly 2018.11 猜价格 (模拟)
分三种情况: 1.k=1.此时每次都说反话,反着二分即可. 2.1<k <= n.那么在前n次问答中一定会出现一次错误,通过不断输出1找出那个错误发生的位置(若回答是>那这就是错误) ...
- EOJ Monthly 2018.2
A. 坑爹的售票机 题意 用\(1,5,10,25,50,100\)的纸币买\(n\)张单价为\(p\)的船票,且一次性最多买\(k\)张,求钱数恰好时最少需要多少张纸币. Hard: \(n,k,p ...
随机推荐
- Understanding on 'Error to Origin (50x)' , 'Internal CDN Error (50x)' and 'External Error (50x)' in Chartron
Overview This document explains about definition of these values on OUI Chartron. Definition of Erro ...
- selenium webdriver——多表单切换与多窗口切换
多表单切换 >>在Web应用中经常会遇到frame/iframe表单嵌套页面的应用,WebDriver只能在一个页面上对元素识别与定位,对于frame/iframe 表单内嵌页面上的元素无 ...
- 【转】深入理解 C# 协变和逆变
http://www.cnblogs.com/qixuejia/p/4383068.html 深入理解 C# 协变和逆变 msdn 解释如下: “协变”是指能够使用与原始指定的派生类型相比,派生程 ...
- UVA 11991 vector
Though Rujia Liu usually sets hard problems for contests (for example, regional contests likeXi’an 2 ...
- SQLalchemy 使用记录
1.models.py中添加该方法,可通过该方法转dict #驼峰 def to_hump_dict(self): return {commonUtils.str2Hump(c.name): geta ...
- 【05】Vue 之 实例详解与生命周期
Vue的实例是Vue框架的入口,其实也就是前端的ViewModel,它包含了页面中的业务逻辑处理.数据模型等,当然它也有自己的一系列的生命周期的事件钩子,辅助我们进行对整个Vue实例生成.编译.挂着. ...
- Python 使用cx_freeze 生成exe文件【转】
Python 使用cx_freeze 生成exe文件 在python中比较常用的python转exe方法有三种,分别是cx_freeze,py2exe,PyInstaller.py2exe恐怕是三 ...
- 洛谷P1135 奇怪的电梯
题目描述 呵呵,有一天我做了一个梦,梦见了一种很奇怪的电梯.大楼的每一层楼都可以停电梯,而且第i层楼 (1<=i<=N)上有一个数字Ki(0<=Ki<=N).电梯只有四个按钮: ...
- input输入框与元素间有间隙
<div class="container"> <button>1</button> <button>2</button> ...
- SQL优化 ASP.NET ADO.NET
原文发布时间为:2009-08-26 -- 来源于本人的百度文章 [由搬家工具导入] 总的考虑方向 1) 根据数据使用的方式来设计数据访问层 2) 缓存数据,避免不必要的操 ...