noip复习模板
我只会这么多
tarjan:codevs 1332
void tarjan(int u)
{
dfn[u]=low[u]=Time++; s.push(u);
for(int i=head[u];~i;i=nxt[i])
{
int v=to[i];
if(!dfn[v]) tarjan(v);
else if(dfn[v]!=-) low[u]=Min(low[u],low[v]);
}
if(dfn[u]==dfn[v])
{
while(!s.empty())
{
int x=s.top(); s.pop();
dfn[x]=-;
tot++;
if(x==u) break;
}
}
}
spfa codevs 2038
#include<iostream>
#include<queue>
#include<stdio.h>
#include<string.h>
using namespace std;
const int inf=0x3f3f3f3f;
int cnt=-,n,e,s,t,ans=inf,p;
int head[],to[],w[],nxt[],d[],used[],pos[];
int Min(int x,int y)
{
return x<y?x:y;
}
void Init()
{
memset(head,-,sizeof(head));
memset(nxt,-,sizeof(nxt));
}
void link(int u,int v,int l)
{
nxt[++cnt]=head[u];
head[u]=cnt;
to[cnt]=v;
w[cnt]=l;
}
void spfa(int s)
{
queue<int>q;
memset(d,inf,sizeof(d));
q.push(s); d[s]=; used[s]=;
while(!q.empty())
{
int u=q.front(); q.pop(); used[u]=;
for(int i=head[u];~i;i=nxt[i])
{
int v=to[i],val=w[i];
if(d[v]>d[u]+val)
{
d[v]=d[u]+val;
if(!used[v])
{
q.push(v);
used[v]=;
}
}
}
}
int tot=;
for(int i=;i<=n;i++)
{
tot+=d[pos[i]];
}
ans=Min(ans,tot);
}
int main()
{
scanf("%d%d%d",&n,&p,&e);
for(int i=;i<=n;i++)
{
int u; scanf("%d",&pos[i]);
}
Init();
for(int i=;i<=e;i++)
{
int u,v,c; scanf("%d%d%d",&u,&v,&c);
link(u,v,c); link(v,u,c);
}
for(int i=;i<=p;i++)
{
spfa(i);
}
printf("%d",ans);
return ;
}
lca 1787
#include<iostream>
#include<stdio.h>
#include<cstring>
using namespace std;
int n,m,u,v,a,b,c,ans,temp1,cnt=-;
int dep[],head[],to[],nxt[];
int fa[][];
void Init()
{
memset(head,-,sizeof(head));
memset(nxt,-,sizeof(nxt));
memset(fa,-,sizeof(fa));
}
int abs(int x)
{
return x>?x:-x;
}
void link(int u,int v)
{
nxt[++cnt]=head[u]; head[u]=cnt;
to[cnt]=v;
}
void dfs(int u,int d)
{
dep[u]=d;
for(int i=head[u];~i;i=nxt[i])
{
int v=to[i];
if(!dep[v])
{
fa[][v]=u;
dfs(v,d+);
}
}
}
int lca(int u,int v)
{
if(dep[u]<dep[v]) swap(u,v);
int deep=dep[u]-dep[v];
for(int i=;i>=;i--)
{
if(deep&(<<i)) u=fa[i][u];
}
if(u==v) return u;
for(int i=;i>=;i--)
{
if(fa[i][u]!=fa[i][v])
{
u=fa[i][u];
v=fa[i][v];
}
}
return fa[][u];
}
inline int calc(int x,int y)
{
int temp=lca(x,y);
return abs(dep[x]-dep[temp])+abs(dep[y]-dep[temp]);
}
int main()
{
scanf("%d%d",&n,&m);
Init();
for(int i=;i<n;i++)
{
int u,v; scanf("%d%d",&u,&v);
link(u,v); link(v,u);
}
dfs(,);
for(int i=;i<=;i++)
{
for(int j=;j<=n;j++)
{
if(fa[i-][j]!=-) fa[i][j]=fa[i-][fa[i-][j]];
}
}
for(int i=;i<=m;i++)
{
scanf("%d%d%d",&a,&b,&c);
int x=lca(a,b);
int y=lca(b,c);
int z=lca(c,a);
if(x==y)
temp1=z;
else
if(y==z)
temp1=x;
else
if(x==z)
temp1=y;
ans=calc(a,temp1)+calc(b,temp1)+calc(c,temp1);
printf("%d %d\n",temp1,ans);
}
return ;
}
二分 跳石头
#include<iostream>
#include<stdio.h>
using namespace std;
int n,m,ans,L;
int a[],mark[];
bool C(int x)
{
int last=,tot=;
for(int i=;i<=n;i++)
{
mark[i]=;
if(a[i]-a[last]<x)
{
tot++;
mark[i]=;
}
else last=i;
}
last=n+;
for(int i=n;i>=;i--)
{
if(a[last]-a[i]<x&&!mark[i]) tot++;
else if(a[last]-a[i]>=x) break;
}
return tot<=m;
}
int main()
{
scanf("%d%d%d",&L,&n,&m);
a[]=; a[n+]=L+;
for(int i=;i<=n;i++)
{
scanf("%d",&a[i]);
}
int l=,r=L+,mid;
while(r-l>)
{
mid=(l+r)/;
if(C(mid)) {l=mid;ans=mid;}
else r=mid;
}
if(C(ans+)) ans++;
printf("%d",ans);
return ;
}
线段树
1012
#include<iostream>
#include<cstdio>
using namespace std;
const int inf=<<;
int m,d,t,size;
int tree[];
int Max(int x,int y)
{
return x>y?x:y;
}
void update(int l,int r,int x,int pos,int num)
{
if(l==r)
{
tree[x]=num;
return;
}
if(pos>(l+r)/) update((l+r)/+,r,x*+,pos,num);
if(pos<=(l+r)/) update(l,(l+r)/,x*,pos,num);
tree[x]=Max(tree[x],Max(tree[x*],tree[x*+]));
}
int query(int l,int r,int x,int a,int b)
{
if(l>b||r<a) return -inf;
if(l>=a&&r<=b) return tree[x];
return Max(query(l,(l+r)/,x*,a,b),query((l+r)/+,r,x*+,a,b));
}
int main()
{
scanf("%d%d",&m,&d);
for(int i=;i<=m;i++)
{
char s[]; scanf("%s",s);
if(s[]=='A')
{
int n,num; scanf("%d",&n); size++;
num=(n+t)%d;
update(,m,,size,num);
}
else if(s[]=='Q')
{
int l; scanf("%d",&l);
t=query(,m,,size-l+,size);
printf("%d\n",t);
}
}
// for(int i=1;i<=3;i++) cout<<tree[i]<<" ";
return ;
}
快速幂:
#include<iostream>
using namespace std;
int n,m,k,x;
int power(int k)
{
int t=,ret=;
while(k>)
{
if(k%==) ret*=t;
t*=t; k/=;
}
return ret;
}
int main()
{
cin>>k;
cout<<power(k);
return ;
}
高精度 3116
#include<iostream>
#include<cstdio>
using namespace std;
string A,B;
struct bigint
{
int d[];
int len;
}a,b,c;
int Max(int x,int y)
{
return x>y?x:y;
}
void add(bigint&a,bigint&b,bigint&c)
{
int x=,temp;
c.len=Max(a.len,b.len);
for(int i=;i<=c.len;i++)
{
temp=a.d[i]+b.d[i]+x;
c.d[i]=temp%; x=temp/;
}
if(x>) c.d[++c.len]=x;
for(int i=c.len;i>=;i--) cout<<c.d[i];
}
int main()
{
cin>>A>>B;
a.len=A.length();
for(int i=;i<A.length();i++)
{
a.d[A.length()-i]=A[i]-'';
}
b.len=B.length();
for(int i=;i<B.length();i++)
{
b.d[B.length()-i]=B[i]-'';
}
add(a,b,c);
return ;
}
noip复习模板的更多相关文章
- NOIP复习篇
NOIP复习篇---枚举 --------------------------------------------------------------------------------------- ...
- django上课笔记4-复习数据库操作-复习模板-Seccion-详细cookie和session的区别
一.复习数据库操作 字段类型 字符串 EmailField(CharField): IPAddressField(Field) URLField(CharField) SlugField(CharFi ...
- NOIP的模板--考前复习
距离NOIP还有25天 可以去放弃一些巨难得题目去搞一些模板了 -------在校老师的原话 一·快排 虽然可以手打,最好用STL,里面有很多优化,会快很多 #include<iostream& ...
- noip级别模板小复习
不是很noip的知识点就不写了. dij什么的太easy就不写了. 缩点 注意\(Tarjan\)在缩边双和求强联通分量时候的区别. 一个要判断是否在栈内一个不要. 最后\(topsort\)来\(d ...
- noip考前模板复习
网络流 Dinic(搭配飞行员) //Serene #include<algorithm> #include<iostream> #include<cstring> ...
- NOIP复习之1 数学数论
noip一轮复习真的要开始啦!!! 大概顺序是这样的 1.数学 2.搜索贪心 3.数据结构 4.图论 5.dp 6.其他 数学 1.数论 数论被称为数学皇冠上的明珠,他的重要性主要在于它是其他学习的祖 ...
- 冲刺NOIP复习,算法知识点总结
前言 离NOIP还有一个星期,匆忙的把整理的算法补充完善,看着当时的整理觉得那时还年少.第二页贴了几张从贴吧里找来的图片,看着就很热血的.当年来学这个竞赛就是为了兴趣,感受计算机之美的. ...
- NOIP常见模板集合
Preface 这篇博客记录的是我联赛前虽然只有两天了的打板子记录. 只求真的能给我起到些作用吧,一般按照难度排序. 而且从这篇博客开始我会用H3的标题代替H4 为了节约篇幅,以下的代码一般均以cla ...
- 【NOIP复习】最短路总结
[模板] /*堆优化Dijkstra*/ void dijkstra() { priority_queue<pair<ll,int>,vector<pair<ll,int ...
随机推荐
- AC日记——单词替换 1.7 21
21:单词替换 总时间限制: 1000ms 内存限制: 65536kB 描述 输入一个字符串,以回车结束(字符串长度<=100).该字符串由若干个单词组成,单词之间用一个空格隔开,所有单词区 ...
- FFT的物理意义
来源:学步园 FFT(Fast Fourier Transform,快速傅立叶变换)是离散傅立叶变换的快速算法,也是我们在数字信号处理技术中经常会提到的一个概念.在大学的理工科课程中,在完成高等数学的 ...
- Gruntjs: grunt-contrib-jst
预编译Underscore模板到JST文件(Underscore:JS工具库) generate JavaScript template functions Gruntfile的配置实例: modul ...
- 利用Spring MVC搭建REST Service
之前写过一篇 利用JAX-RS快速开发RESTful 服务 今天来看下spring-mvc框架如何实现类似的功能: 一.pom.xml <?xml version="1.0" ...
- 打印机设置(PrintDialog)、页面设置(PageSetupDialog) 及 RDLC报表如何选择指定打印机
如果一台电脑同时连接多个打印机,而且每个打印机使用的纸张大小各不相同(比如:票据打印钱用的小票专用张,办公打印机用的是A4标准纸),在处理打印类的需求时,如果不用代码干预,用户必须每次打印时,都必须在 ...
- opencv6.2-imgproc图像处理模块之图像尺寸上的操作及阈值
接opencv6.1-imgproc图像处理模块之平滑和形态学操作,顺带说一句在opencv中的in-place操作就是比如函数的输入图像和输出图像两个指针是相同的,那么就是in-place操作了.比 ...
- C/C++实践笔记_001Helloworld
1.void返回值为空,int返回值Linux c,c++中,Main函数可以返回也可以不返回,普通函数必须返回.C编译松散,很容易结果出错,C++编译严格一些,结果一般会正确C语言不返回不会报错,但 ...
- mvc5+ef6+Bootstrap 项目心得--WebGrid
1.mvc5+ef6+Bootstrap 项目心得--创立之初 2.mvc5+ef6+Bootstrap 项目心得--身份验证和权限管理 3.mvc5+ef6+Bootstrap 项目心得--WebG ...
- unity3d 音频无缝循环
在我做赛车漂移的时候,漂移的声音断断续续的,搞得我很郁闷 大家可以随便找个音效然后循环播放去仔细听 你会发现当音效播放完成一次之后循环播放第二次时会停顿一下 我做赛车漂移如果中途停顿了体验是非常不好的 ...
- 使用docker发布spring cloud应用
本文涉及到的项目: cloud-simple-docker:一个简单的spring boot应用 Docker是一种虚拟机技术,准确的说是在linux虚拟机技术LXC基础上又封装了一层,可以看成是基于 ...