- 1、本文档共21页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Noip 2013 提高组 解题报告.pdf
Noip2013 提高组 解题报告
--ByGreenCloudS
Day1:
第一题:转圈游戏 (快速幂)
根据题目,答案明显是(x+10^km)modn,化简一下,就成了(x+m(10^kmodn)mod
n)modn,所以,只需要求出10^kmodn 即 ,可以使用快速幂来求解复杂度, O(log
k) f(i)=10^imodn, f(i)=f(i-1)*10modn, f(i)
。(另一个算法,设 则 然后求出 的循环节,
复杂度O(n))
代码(C++):
#include cstdio
#include cstring
int k;
long long ans;
int n,m,x;
long long Exp(int y){
if(!y)return 1;
if(y==1)return 10%n;
if(y1){
return(((Exp(y1)*Exp(y1))%n)*10)%n;
}else return(Exp(y1)*Exp(y1))%n;
}
int main(){
scanf(%d%d%d%d,n,m,k,x);
ans=Exp(k);
ans*=m;
ans%=n;
ans+=x;
ans%=n;
printf(%lld,ans);
return 0;
}
第二题:火柴排队 (贪心+逆序对)
对距离公式化简得:
(ai-bi)^2= (ai^2-2aibi+bi^2)= ai^2+ bi^2- aibi (ai-bi)^
∑ ∑ ∑ ∑ ∑ 要求∑ 最小,就只
aibi a1a2…an,b1b2..bn aibi
需要∑ 最大即可。这里有个贪心,当 时,∑ 最
大。证明如下:
ab,cd, ac+bdad+bc a(c-d)b(c-d), ab ab
若存在 且 ,则 则 ,与 矛盾,所以若
ab,cd,则ac+bdad+bc
将此式子进行推广:
a1a2a3...an,b1b2...bn aibi (ai-bi)^
当 的情况下∑ 最大,即∑ 最小。
然后,将两个序列分别排序,确定每对数的对应关系,明显,同时移动两个序列
中的数等效于只移动一个序列中的数,那么,我们就保持一个序列不动,然后根
据另外那个序列中的数对应的数的位置,重新定义一个数组,求逆序对个数,就
是答案。
例如:
对于数据:
4
314
3 14
先排序:
1 34
1 34
1 3 1 1
保持序列 不动,那么序列 中的 就对应序列 中的 位置, 就对应序列
1 1 1 3 4 1 4
中的 位置, 就对应序列 中的 位置, 就对应序列 中的 位置,那么重定
义数组为:
134
这个序列的逆序对为(2,1),所以答案是 。1
求逆序对方法:
1. 归并排序
2. 把数组扫一遍,顺序把每个数加入BIT或者是线段树等数据结构中,同
时查询比这个数大的数有几个,加入答案。
复杂度 :O(nlogn)
C++
代码( )(树状数组)
您可能关注的文档
最近下载
- 小学数学二 轴对称和平移作业设计.docx
- 人教版(2024新版)七年级全一册《信息技术》第2单元直播网络我来建第10课 综合所学建网络 教学设计.docx
- 2023执业药师《西药二》考试真题及答案解析(完整版).pdf
- 妇女儿童权益维护培训ppt课件.pptx
- 2024年河北省继续医学教育公共必修课参考答案.docx VIP
- 《2023 CSCO结直肠癌诊疗指南》解读(1)PPT课件.pptx VIP
- 湘教版三年级上册科学《土壤的保护》土壤PPT课件.pptx VIP
- 贵州省高中学生登记表.pdf
- FAA城市空中交通(UAM)运行概念 2023年 V2.0 .pdf VIP
- 市政排污管施工规范标准[详].ppt
文档评论(0)