现场只做出前三题w

  不过不管怎样这既是第一次认真打BC

  又是第一次体验用在线编译器调代码

  订正最后一题花了今天一整个下午(呜呜

  收获还是比较大的^_^


 Delete

wld有n个数(a1,a2,...,an),他希望进行k次删除一个数的操作,使得最后剩下的n−k个数中有最多的不同的数,保证1≤n≤100,0≤k<n,1≤ai≤n(对于任意1≤i≤n)

  比较简单的贪心...

  把出现一次以上的多于一次的部分都删除掉

  如果k依然>0就要删去k种不同的数


Multiple

wld有一个序列a[1..n], 对于每个1≤i<n, 他希望你求出一个最小的j(以后用记号F(i)表示),满足i<j≤n, 使aj为ai的倍数(即aj mod ai=0),若不存在这样的j,那么此时令F(i) = 0 保证1≤n≤10000,1≤ai≤10000 对于任意 1≤i≤n, 且对于任意1≤i,j≤n(i!=j),满足ai != aj

  n^1.5次的大暴力即可

  发现BC好多题目都是用这种方法...在此之前并不认为这样可以过

  对于每个数枚举它所有的因数,刷新它们的f[i]值


Code

wld有一个长度为n的序列a1..an
wld想要你给出下面这段c++代码的输出:
int calc()
{int res=0;for(int i=1;i<=n;i++)for(int j=1;j<=n;j++){res+=gcd(a[i],a[j])*(gcd(a[i],a[j])-1);res%=10007;}return res;
}
保证1≤n≤10000,1≤ai≤10000 (对于任意1≤i≤n)

  我的做法是n^1.5次的,但是发现题解是nlog(n)

  但上次莫比乌斯反演只看到一半...所以先弃疗吧

  讲讲n^1.5次的做法

  首先n^1.5的复杂度将每个数的因子打上标记

  我们可以枚举最大公约数d,如果有x个数有d这个因子

  那么就累计x*(x-1)次这个答案

  但是显然我们会发现问题

  如果两个数有4这个因子,那么在统计2的时候又会统计一次!

  解决方法很简单,我们可以预先处理出每个数应累计的答案f[i]

  枚举最大公约数d的同时,再枚举d的因子i,减去这个因子的答案

  注意:这里的答案也是处理过的答案,即f[i]

  最后单独累计i=j时的情况

  

  手速太慢...原因有好多个

  开始写的时候把+=看成了*=

  所以写了乘法逆元...然后调了半天输出了很多中间过程才发现错误

  然后还忘记了i=j的情况

  后来WA了一发,是因为枚举最大公约数的时候应枚举到a[i]的最大值而不是n

  刚开始没查出来,又开始证明算法的思路即f[i]的计算是否正确

  改来改去越来越离谱..突然发现是后面的问题

  然后就1h+辣> <


Lucky

wld有n个数(a1...an)
保证对于任意1≤i≤n,1≤ai≤n
wld有一个常数k保证2≤k≤2∗n
为了消除歧义保证k为奇数
他有m个询问 每个询问有参数l1,r1,l2,r2 保证(1≤l1≤r1<l2≤r2≤n) 对于每个询问你需要回答有多少个二元组(i,j)满足: l1≤i≤r1且l2≤j≤r2且ai+aj=k 保证1≤n≤30000,1≤m≤30000

  

  恩..这道题在考场上确实是写不出来的..

  今天下午去学习了一下莫队算法...觉得很有趣...

  

  莫队算法就是建立在分块基础上,离线解决一系列区间询问问题

  首先这道题假设已知[l,r]中相加=k的对数

  那么我们可以通过复杂度不高的代价得知[l-1,r][l+1,r][l,r-1][l,r+1]的答案

  刚开始是打算用log级的倍增做的..但是交了一发TLE了

  这道题询问的是[l1,r1][l2,r2]中满足条件的对数

  如何转换成单个区间上面[l,r]中相加=k的对数呢

  假设题目中让我们求的是一个在区间A,一个在区间B的答案,我们假设为F(A,B),并且令F中统计的数对为有序的

  即只统计a[i]+a[j]=k且(i<j)的情况

  可以证明得出F(A,B) = F(A+C+B,A+C+B)-F(A+C,A+C)-F(B+C,B+C)+F(C,C)

  F(A+C+B,A+C+B)-F(A+C,A+C)-F(C+B,C+B)+F(C,C)

  = F(A,A)+F(A,C)+F(A,B)+F(C,C)+F(C,B)+F(B,B)-F(A,A)-F(A,C)-F(C,C)-F(C,C)-F(C,B)-F(B,B)+F(C,C)

  = F(A,B)

  转化成了4部分两区间相等的F,也就是可以用上面的莫队算法来解决了

  最后一个问题,就是转移的时候如何从log(n)转化成O(1)

  在执行莫队的同时,即l,r一位一位移动的时候,用一个数组记录当前区间内某个数出现的次数就可以了...

  


  涨了177w

  手速还是慢慢慢

  居然过了一个周末一下子就27号了呢

  居然再过两天又要回家了呢

  

  27/.Apr.

  

转载于:https://www.cnblogs.com/mjy0724/p/4460991.html

BestCoder Round #39 解题报告相关推荐

  1. 贪心 BestCoder Round #39 1001 Delete

    题目传送门 1 /* 2 贪心水题:找出出现次数>1的次数和res,如果要减去的比res小,那么总的不同的数字tot不会少: 3 否则再在tot里减去多余的即为答案 4 用set容器也可以做,思 ...

  2. 群赛 round#8 解题报告一 (swop,ranwen,easy)

    群赛 round#8 解题报告一 赛制: OI 难度: noip T1 交换!交换!(swop) [问题描述] ljm喜欢交换物品,他觉得这样可以与更多人分享好的事物. 有一天,lzx给了ljm n本 ...

  3. HDU 5228 ZCC loves straight flush( BestCoder Round #41)

    题目链接:ZCC loves straight flush 题面: ZCC loves straight flush Time Limit: 2000/1000 MS (Java/Others)    ...

  4. 解题报告(一)D、(CROC 2016 - Final Round C)Binary Table(矩阵 + 状态压缩 + FWT)(3.5)

    繁凡出品的全新系列:解题报告系列 -- 超高质量算法题单,配套我写的超高质量题解和代码,题目难度不一定按照题号排序,我会在每道题后面加上题目难度指数(1∼51 \sim 51∼5),以模板题难度 11 ...

  5. Codeforces Round #700 (Div. 2)A~D2解题报告

    Codeforces Round #700 (Div. 2)A~D2解题报告 A Yet Another String Game 原题链接 http://codeforces.com/contest/ ...

  6. Codeforces Round #693 (Div. 3)A~G解题报告

    Codeforces Round #693 (Div. 3)A~G解题报告 A Cards for Friends 原题信息 http://codeforces.com/contest/1472/pr ...

  7. Codeforces Round #697 (Div. 3)A~G解题报告

    Codeforces Round #697 (Div. 3)A~G解题报告 题 A Odd Divisor 题目介绍 解题思路 乍一想本题,感觉有点迷迷糊糊,但是证难则反,直接考虑没有奇数因子的情况, ...

  8. Codeforces Round #698 (Div. 2) A-E解题报告与解法证明

    Codeforces Round #698 (Div. 2) A-E解题报告与解法证明 题目解法总体概括 A Nezzar and Colorful Balls #include <bits/s ...

  9. 【解题报告】CF DIV3 #ROUND 734 A~D1

    [解题报告]CF DIV2 #ROUND 707 A~D 比赛链接 比赛评价: 一般性,有段时间没打了,甚至忘记多组输入hh.顺便吐槽一下翻译软件确实不行,以后还是直接看英文好了 A. Polycar ...

最新文章

  1. python networkx教程_如何在python中使用networkx绘制有向图?
  2. 为了让AI不断打怪升级,DeepMind打造了一个“元宇宙”
  3. 十个问题理解Linux epoll工作原理
  4. oracle 01013 02063,Oracle11g dblink用户密码大写限制-ORA-02063: preceding line from FOR244_DBLINK...
  5. 这本书人手一本,杠精能少97%?
  6. ElasticSearch索引
  7. 拒绝PPT手机?魅族首款真无孔手机将开启众筹
  8. 【包邮免费送】Python 全栈知识图谱
  9. fread返回值0 feof返回值为16 问题解决。
  10. 类似于QQ游戏百万人同时在线的服务器架构实现
  11. 基于Java的中华文化传播系统(含数据库文档)
  12. 获取高德地图POI数据
  13. 红外图像高低温校正【待补充】
  14. 网站使用微软雅黑需要版权吗
  15. 产品经理学项目管理04:企业管理金字塔
  16. 42表盘直径是从哪测量_手表尺寸怎么测量的?手表尺寸测量方法
  17. 机器学习_经典模型_逻辑回归(logistic regression)
  18. IGBT的双脉冲测试实验
  19. 如何查看网站的收录与排名
  20. Linux:删除重复文件工具fdupes

热门文章

  1. 【SPOJ - DQUERY】D-query(权值树状数组 或 主席树 或 莫队)
  2. Idea Spring Boot配置文件.yaml或.properties不能自动提示的有效解决办法
  3. mysql 主从 keepalived_MySQL之双向主从加keepalived高可用
  4. html验证邮箱自动,html5+JavaScript进行邮箱地址验证
  5. c3p0-config.xml
  6. 剑指offer:45-48记录
  7. (多线程)leetcode1195. 交替打印字符串 最简单解法一个变量搞定
  8. (八)nodejs循序渐进-事件驱动(进阶篇)
  9. LINUX下动态链接库的使用-dlopen dlsym dlclose dlerror
  10. C++(18)--复制构造函数