【NOIP2013TG】solution
链接:https://www.luogu.org/problem/lists?name=&orderitem=pid&tag=83%2C30
D1T1:转圈游戏(circle)
题意:看题目。。
解题思路:快速幂求\( (10^k m) mod n \)即可。时间效率\( O (\lg k) \)
#include<stdio.h>
#define ll long long
#define For(i,a,b) for(int i=a; i<=b; i++)
#define Ford(i,a,b) for(int i=a; i>=b; i--)
#define File(fn) freopen(fn".in","r",stdin);freopen(fn".out","w",stdout);
int n,m,k,x;
inline int in(){
int x=,f=;
char ch=getchar();
while(ch<''||ch>'') f=ch=='-'?-:,ch=getchar();
while(ch>=''&&ch<='') x=x*+ch-'',ch=getchar();
return x*f;
}
inline void print(int x,char ch){
if (!x){
putchar('');
putchar(ch);
return;
}
if (x<){
putchar('-');
x*=-;
}
char num[];
short cnt=;
while(x) num[++cnt]=x%+'',x/=;
while(cnt) putchar(num[cnt--]);
putchar(ch);
}
inline ll ksm(int a,int k){
if (!k) return ;
if (!(k^)) return a;
ll t=ksm(a,k>>)%n;
t*=t;t%=n;
if (k&) t*=a;
t%=n;
return t;
}
int main(){
n=in(),m=in(),k=in(),x=in();
print((ksm(,k)*m%n+x)%n,'\n');
}
D1T2:火柴排队(match)
题意:将一个数组中元素进行几次交换后使得这个数组的大小顺序与另一个数组相同。
解题思路:离散后排序求逆序对数。时间效率\( O(n \lg n) \).
#include<stdio.h>
#include<algorithm>
#define ll long long
#define For(i,a,b) for(int i=a; i<=b; i++)
#define Ford(i,a,b) for(int i=a; i>=b; i--)
#define File(fn) freopen(fn".in","r",stdin);freopen(fn".out","w",stdout);
#define mod 99999997
using namespace std;
struct zxy{
int num,no;
}a[],b[];
int n,ans=,c[],BIT[];
inline int in(){
int x=,f=;
char ch=getchar();
while(ch<''||ch>'') f=ch=='-'?-:,ch=getchar();
while(ch>=''&&ch<='') x=x*+ch-'',ch=getchar();
return x*f;
}
inline void print(int x,char ch){
if (!x){
putchar('');
putchar(ch);
return;
}
if (x<){
putchar('-');
x*=-;
}
char num[];
short cnt=;
while(x) num[++cnt]=x%+'',x/=;
while(cnt) putchar(num[cnt--]);
putchar(ch);
}
bool cmp(zxy a,zxy b){
return a.num<b.num;
}
void init(){
n=in();
For(i,,n) a[i].num=in(),a[i].no=i;
For(i,,n) b[i].num=in(),b[i].no=i;
sort(a+,a+n+,cmp);
sort(b+,b+n+,cmp);
For(i,,n) c[b[i].no]=a[i].no;
}
inline int lowbit(int k){
return k&(-k);
}
inline void update(int x,int ad){
while(x<=n){
BIT[x]+=ad;
x+=lowbit(x);
}
}
inline int query(int x){
int sum=;
while(x){
sum+=BIT[x];
x-=lowbit(x);
}
return sum;
}
void solve(){
For(i,,n){
update(c[i],);
ans+=(i-query(c[i]));
ans%=mod;
}
print(ans,'\n');
}
int main(){
init();
solve();
return ;
}
D1T3:货车运输(truck)
题意:给你一张图,问你从一个点到另一个点的路径上的最大的路径上最小的权值是多少,如果不能联通输出-1.
解题思路:首先为了方便处理,我们将所有点向0号点连一条权值为-1的边,这样保证所有点可以联通的同时会输出答案-1.接下来,我们考虑题意要求的使得“最小的尽可能”大的条件,发现可以使用最大生成树实现,接下来考虑查询两点间的树上路径中权值最小的边,使用LCA即可作答,这里可以使用所有的LCA算法,我使用了理解与实现都较为容易倍增求LCA,时间效率为\( O(m \lg m+q \lg n) \)。
附优化了各种常数的代码(貌似还可以继续优化)。
#include<stdio.h>
#include<algorithm>
#define INF 0x7fffffff
using namespace std;
struct zxy{
int x,y,l;
}edge[];
struct tree{
int next,to,v;
}tr[];
int father[],fa[][],n,m,q,cnt=,used[],deep[],head[],dis[][];
inline int in(){
int x=,f=;
char ch=getchar();
while(ch<''||ch>'') f=ch=='-'?-:,ch=getchar();
while(ch>=''&&ch<='') x=x*+ch-'',ch=getchar();
return x*f;
}
inline int find(int x){
return father[x]=father[x]==x?x:find(father[x]);
}
bool cmp(zxy a,zxy b){
return a.l>b.l;
}
inline void ins(int x,int y,int l){
edge[++cnt].x=x,edge[cnt].y=y,edge[cnt].l=l;
}
inline void ins2(int x,int y,int l){
tr[++cnt].to=y,tr[cnt].next=head[x],head[x]=cnt,tr[cnt].v=l;
}
void init(){
n=in(),m=in();
int x,y,l;
for (int i=; i<=m; ++i){
x=in(),y=in(),l=in();
ins(x,y,l);ins(y,x,l);
}
}
bool mst(){
for(register int i=; i<=n; ++i)
father[i]=i,ins(,i,-),ins(i,,-);
sort(edge+,edge+cnt+,cmp);
int k=;
for(register int i=; i<=cnt; ++i)
if (find(edge[i].x)!=find(edge[i].y)){
father[find(father[edge[i].x])]=find(edge[i].y);
used[++k]=i;
}
cnt=;
for(register int i=; i<=k; ++i)
ins2(edge[used[i]].x,edge[used[i]].y,edge[used[i]].l),ins2(edge[used[i]].y,edge[used[i]].x,edge[used[i]].l);
return !(k^n);
}
inline void dfs(int x,int d,int f){
deep[x]=d;fa[x][]=f;
for (register int i=head[x]; i; i=tr[i].next)
if (tr[i].to!=f) dis[tr[i].to][]=tr[i].v,dfs(tr[i].to,d+,x);
}
void init_LCA(){
for(int j=; j<=; ++j)
for(register int i=; i<=n; ++i)
fa[i][j]=fa[fa[i][j-]][j-],dis[i][j]=min(dis[i][j-],dis[fa[i][j-]][j-]);
}
inline int query(int x,int y){
if (deep[x]<deep[y]){int t=x;x=y,y=t;}
int mi=INF,d=deep[x]-deep[y];
if (d) for(register int i=; d&&i<=; ++i,d>>=) if (d&) mi=min(mi,dis[x][i]),x=fa[x][i];
if (!(x^y)) return mi;
for(register int i=; i>=; --i) if (fa[x][i]!=fa[y][i]) mi=min(mi,min(dis[x][i],dis[y][i])),x=fa[x][i],y=fa[y][i];
mi=min(mi,min(dis[x][],dis[y][]));
return mi;
}
void lca(){
q=in();
dfs(,,);init_LCA();
for(register int i=; i<=q; ++i){
register int x=in(),y=in();
printf("%d\n",query(x,y));
}
}
int main(){
init();
mst();
lca();
return ;
}
D2T1:积木大赛(block)
题意:看题目。。
解题思路:暴力模拟,具体见代码。时间效率\(O(n)\)。
#include<stdio.h>
#define ll long long
#define For(i,a,b) for(int i=a; i<=b; i++)
#define Ford(i,a,b) for(int i=a; i>=b; i--)
#define File(fn) freopen(fn".in","r",stdin);freopen(fn".out","w",stdout);
int a[],n,h,t,ans;
inline int in(){
int x=,f=;
char ch=getchar();
while(ch<''||ch>'') f=ch=='-'?-:,ch=getchar();
while(ch>=''&&ch<='') x=x*+ch-'',ch=getchar();
return x*f;
}
inline void print(int x,char ch){
if (!x){
putchar('');
putchar(ch);
return;
}
if (x<){
putchar('-');
x*=-;
}
char num[];short cnt=;
while(x) num[++cnt]=x%+'',x/=;
while(cnt) putchar(num[cnt--]);
putchar(ch);
}
int main(){
n=in();
For(i,,n) a[i]=in();
h=;
For(i,,n)
if (a[i]<a[i-]) ans+=a[i-]-a[h],h=i;
ans+=a[n]-a[h];
print(ans,'\n');
}
D2T2:花匠(flower)
题意:看题目啊。。。
解题思路:显然题目就是叫你找一个最长的连续上升子序列/下降子序列,所以乱搞一下就好了。时间效率\(O(n)\).
#include<stdio.h>
#define ll long long
#define For(i,a,b) for(int i=a; i<=b; i++)
#define Ford(i,a,b) for(int i=a; i>=b; i--)
#define File(fn) freopen(fn".in","r",stdin);freopen(fn".out","w",stdout);
int a[],ans=,flag=-,n;
inline int in(){
int x=,f=;
char ch=getchar();
while(ch<''||ch>'') f=ch=='-'?-:,ch=getchar();
while(ch>=''&&ch<='') x=x*+ch-'',ch=getchar();
return x*f;
}
inline void print(int x,char ch){
if (!x){
putchar('');
putchar(ch);
return;
}
if (x<){
putchar('-');
x*=-;
}
char num[];
short cnt=;
while(x) num[++cnt]=x%+'',x/=;
while(cnt) putchar(num[cnt--]);
putchar(ch);
}
int main(){
n=in();
For(i,,n) a[i]=in();
For(i,,n){
if (a[i]>a[i-]&&(flag-)) ans++,flag=;
if (a[i]<a[i-]&&flag) ans++,flag=;
}
print(ans,'\n');
}
本文由Melacau编写,Melacau代表M星向您问好,如果您不是在我的博客http://www.cnblogs.com/Melacau上看到本文,请您向我联系,email:13960948839@163.com.
【NOIP2013TG】solution的更多相关文章
- about家庭智能设备部分硬件模块功能共享【协同工作】solution
本人设备列表: Onda tablet {Android} wifi Desktop computer {win7.centos7} 外接蓝牙adapter PS interface 键盘.鼠标{与同 ...
- 【leetcode】solution in java——Easy1
转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6409067.html 1:Hamming distance The Hamming distance betw ...
- 【436】Solution for LeetCode Problems
Coding everyday. ^_^ 1. Two Sum 重点知识:指针可以存储数值,通过 malloc 新建数组 int* returnSize:Size of the return arra ...
- 【NOIP2012TG】solution
D1T1(Vigenere) 题意:给你一个原串与一个密码串,问你按照题意规则加密后的密文. 解题思路:暴力模拟. #include <stdio.h> ],c[],u1[],u2[]; ...
- 【NOIP2014TG】solution
链接:https://www.luogu.org/problem/lists?name=&orderitem=pid&tag=83|31 D1T1(rps) 题意:给你一个周期,以及胜 ...
- 【NOIP2016TG】solution
传送门:https://www.luogu.org/problem/lists?name=&orderitem=pid&tag=83%7C33 D1T1(toys) 题意:有n个小人, ...
- 【NOIP2015TG】solution
链接:https://www.luogu.org/problem/lists?name=&orderitem=pid&tag=83%2C32 D1T1(magic) 题意:看题目.. ...
- 【NOIP2011TG】solution
老师最近叫我把NOIPTG的题目给刷掉,于是就开始刷吧= = 链接:https://www.luogu.org/problem/lists?name=&orderitem=pid&ta ...
- 【leetcode】solution in java——Easy5
转载请注明原文地址: 21:Assign Cookies Assume you are an awesome parent and want to give your children some co ...
随机推荐
- 201621123060《JAVA程序设计》第九周学习总结
1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结集合与泛型相关内容. 2. 书面作业 本次作业题集集合 1. List中指定元素的删除(题集题目) 1.1 实验总结.并回答:列举至 ...
- 201621123062《Java程序设计》第一周学习总结
1.本周学习总结 关键词: 初步熟悉Java的基本组成.语言特点(简单性.结构中立性).运行环境.简单语法等. 关键概念之间的联系: 1.JVM是Java程序唯一认识的操作系统,其可执行文件为.cla ...
- IOS UITextView自适应高度
LOFTER app需要实现了一个类似iPhone短信输入框的功能,它的功能其实蛮简单,就是:[UITextView的高度随着内容高度的变化而变化].实现思路应该是: 在UITextView的text ...
- python利用twilio模块给自己发短信
1.访问http://twilio.com/并填写注册表单.注册了新账户后,你需要验证一个手机号码,短信将发给该号码. 2.Twilio 提供的试用账户包括一个电话号码,它将作为短信的发送者.你将需要 ...
- 接触JS的变量
刚刚接触到js,写的代码都是很简单的,制单的概念也相当少,新学习的就是变量.let和const以及js的数据类型. 变量的内容有五个,我就不一一介绍了,重点在于: 在 JavaScript 中,使用变 ...
- 构建微服务开发环境8————Hello 微服务
[内容指引] 1.用IDEA打开微服务项目; 2.更新Maven依赖: 3.IntelliJ IDEA JDK配置; 4.修改代码: 5.运行微服务: 6.将代码变更提交到Github. 经过前面的努 ...
- 从PRISM开始学WPF(八)導航Navigation?
0x6Navigation Basic Navigation Prism中的Navigation提供了一种类似导航的功能,他可以根据用户的输入,来刷新UI. 先看一个最简单的例子,通过按钮来导航到一个 ...
- SLF4J - 一个允许你统一日志记录API的抽象层
一.什么是SLF4J 我们在做Java开发时,如果需要记录日志,有很多日志API可供选择,如: java.util.logging Apache log4j logback SLF4J又是个什么东东呢 ...
- webpack打包性能优化
1. 使用 gzip 压缩打包后的 js 文件 这个方法优化浏览器下载时的文件大小(打包后的文件大小没有改变) webpack.config.prod.js 中 var CompressionWebp ...
- 【转】python3 urllib.request 网络请求操作
python3 urllib.request 网络请求操作 基本的网络请求示例 ''' Created on 2014年4月22日 @author: dev.keke@gmail.com ''' im ...