【CCCC天梯赛决赛】
cccc的天梯赛决赛,水题一样的水,中档题以上的还是没做出来。补了一下题,觉得其实也不是很难,主要是练的少。
L2-1:红色预警 并查集
我做的时候想不到并查集,想到了也不一定做的出来,都是其实不难。
每次失去一个城市,重新计算过并查集,比较几个根节点,如果根节点增加了那么就是改变了连通性。
#include<cstdio>
#define N 505
#define M 5005
using namespace std;
int n,m,k,g,cnt,newcnt;
int f[N],u[M],v[M];
int find(int x)
{
if(f[x]!=x)
f[x]=find(f[x]);
return f[x];
}
void un(int a,int b)
{
int fa=find(a),fb=find(b);
if(fa!=fb)
f[fa]=fb;
}
void solve()
{
f[g]=-;
newcnt=;
for(int i=; i<n; i++)if(f[i]!=-)f[i]=i;
for(int i=; i<m; i++)
if(f[u[i]]!=-&&f[v[i]]!=-)
un(u[i],v[i]);
for(int i=; i<n; i++)if(f[i]==i)
newcnt++;
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=; i<n; i++)f[i]=i;
for(int i=; i<m; i++)
{
scanf("%d%d",&u[i],&v[i]);
un(u[i],v[i]);
}
scanf("%d",&k);
for(int i=; i<n; i++)if(f[i]==i)
cnt++;
for(int i=; i<=k; i++)
{
scanf("%d",&g);
solve();
if(cnt<newcnt)printf("Red Alert: City %d is lost!\n",g);
else printf("City %d is lost.\n",g);
cnt=newcnt;
if(k==i&&k==n)printf("Game Over.");
}
}
L2-2列车调度 最长上升子序列 O(nlogn)解法
这题题意是求1到n的一个排列里可以分成最少多少个下降子序列,如果做过导弹拦截那么容易地可以知道问题等价于求最长上升子序列,而且要用O(nlogn)的解法。
s[i]s[i]表示上升子序列的长度为i时最后一个数的最小值。
当i<j时,有s[i]<s[j],因为长度比较长的子序列,它末尾的值也肯定更大。
有了这个性质,就可以用二分查找了。
每次找出s里值小于a[i]的最大下标j,把s[j]更新为a[i]。
#include<cstdio>
#include<algorithm>
using namespace std;
#define N 100005
int n,a[N],s[N],ans=;
int main()
{
scanf("%d",&n);
for(int i=; i<=n; i++)
{
s[i]=0x3f3f3f3f;
scanf("%d",&a[i]);
}
s[]=;
for(int i=; i<=n; i++)
{
int l=,r=i-;
while(l<r){
int m=(l+r)>>;
if(s[m]<=a[i])l=m+;
else r=m;
}
if(s[l]<=a[i]){
s[l+]=min(s[l+],a[i]);
ans=max(ans,l+);
}else{
s[l]=min(s[l],a[i]);
ans=max(ans,l);
}
}
printf("%d",ans);
}
L3-1 是否完全二叉搜索树
完全二叉树的概念:从上到下,每一层从左到右填充树的节点。
题意是给你n个数,从根节点开始每次和节点比较,如果更大,那就插入左子树,更小就插入右子树。
遍历的最后一个数字如果刚好是第n个节点,那就是完全二叉树。
#include<cstring>
#include<cstdio>
using namespace std;
int n,t,k,tree[<<];
void build(int w,int v)
{
if(tree[w]==-)tree[w]=v;
else if(v>tree[w]) build(w<<,v);
else build(w<<|,v);
}
int main()
{
memset(tree,-,sizeof tree);
scanf("%d",&n);
for(int i=; i<n; i++)
{
scanf("%d",&t);
build(,t);
}
k=;
for(int i=; i<=n; k++)
if(tree[k]!=-)
{
printf("%d%c",tree[k],i==n?'\n':' ');
i++;
}
if(k==n+)puts("YES");
else puts("NO");
}
【CCCC天梯赛决赛】的更多相关文章
- 记第一届 CCCC-团体程序设计天梯赛决赛 参赛
其他都没什么,上午报道,下午比赛两个半小时,最后139分 但四我超遗憾的是,最后在做L3-1二叉搜索树,因为看到有辣么多人做出来,可是我没做出来啊 比赛结束后看了看其他两道当场吐血,L3-3直捣黄龙不 ...
- 记cccc天梯赛第三届决赛
首先我很想知道,为什么我没有参加初赛,就可以去决赛,这个究竟有没有初赛,这真是未解之谜. 其次,会长说得不错,菜是原罪.不知道这次的表现能不能把我送去湘潭挑战赛.... 我身边 ...
- 2016年团体程序设计天梯赛-决赛 L2-3. 互评成绩(25)
学生互评作业的简单规则是这样定的:每个人的作业会被k个同学评审,得到k个成绩.系统需要去掉一个最高分和一个最低分,将剩下的分数取平均,就得到这个学生的最后成绩.本题就要求你编写这个互评系统的算分模块. ...
- 2016年团体程序设计天梯赛-决赛 L1-8. Left-pad(20)
根据新浪微博上的消息,有一位开发者不满NPM(Node Package Manager)的做法,收回了自己的开源代码,其中包括一个叫left-pad的模块,就是这个模块把javascript里面的Re ...
- 2016年团体程序设计天梯赛-决赛 L1-7. 到底是不是太胖了(10)
据说一个人的标准体重应该是其身高(单位:厘米)减去100.再乘以0.9所得到的公斤数.真实体重与标准体重误差在10%以内都是完美身材(即 |真实体重-标准体重| < 标准体重x10%).已知市斤 ...
- 2016年团体程序设计天梯赛-决赛 L1-6. 一帮一(15)
“一帮一学习小组”是中小学中常见的学习组织方式,老师把学习成绩靠前的学生跟学习成绩靠后的学生排在一组.本题就请你编写程序帮助老师自动完成这个分配工作,即在得到全班学生的排名后,在当前尚未分组的学生中, ...
- 2016年团体程序设计天梯赛-决赛 L1-5. 是不是太胖了(5)
据说一个人的标准体重应该是其身高(单位:厘米)减去100.再乘以0.9所得到的公斤数.已知市斤是公斤的两倍.现给定某人身高,请你计算其标准体重应该是多少?(顺便也悄悄给自己算一下吧……) 输入格式: ...
- 2016年团体程序设计天梯赛-决赛 L1-3. 出租(20)
下面是新浪微博上曾经很火的一张图: 一时间网上一片求救声,急问这个怎么破.其实这段代码很简单,index数组就是arr数组的下标,index[0]=2 对应 arr[2]=1,index[1]=0 对 ...
- 2016年团体程序设计天梯赛-决赛 L1-2. I Love GPLT(5)
这道超级简单的题目没有任何输入. 你只需要把这句很重要的话 —— “I Love GPLT”——竖着输出就可以了. 所谓“竖着输出”,是指每个字符占一行(包括空格),即每行只能有1个字符和回车. #i ...
随机推荐
- poj1273 Drainage Ditches
Drainage Ditches Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 68414 Accepted: 2648 ...
- js中控制小数点的显示位数的技术整理
js中自带方法控制小数点的显示位数(四舍五入) alert((12.9299).toFixed(2)); //12.93 alert((12.9243).toFixed(2)); //12.92 小数 ...
- umeng社交分享最新版5.0的跨进程使用崩溃的问题及解法-Android
先简单介绍下5.0版的变化.5.0最大的特色是调用简单,采用了链式语法,形如: new ShareAction(context).setPlatform(share_media) .withText( ...
- 逗号分隔的字符串转换为行数据(collection)(续)
逗号分隔的字符串转行数据的存储过程一个: CREATE OR REPLACE FUNCTION SP_YX_SPLIT ( p_list CLOB, p_sep VARCHAR2 := ',' ) R ...
- Android中如何设置RadioButton在文字的右边,图标在左边
from:http://blog.csdn.net/sunnyfans/article/details/7901592?utm_source=tuicool&utm_medium=referr ...
- PAT 1005. 继续(3n+1)猜想 (25) JAVA
当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数.例如对n=3进行验证的时候,我们需要计算3.5.8.4.2.1,则当我们对n=5.8.4.2进行验证的时候,就可以直接 ...
- Android 系统稳定性 - ANR(二)(转)
编写者:李文栋P.S. OpenOffice粘贴过来后格式有些混乱. 1.2 如何分析ANR问题 引起ANR问题的根本原因,总的来说可以归纳为两类: 应用进程自身引起的,例如: 主线程阻塞.挂起.死循 ...
- lecture15-自动编码器、语义哈希、图像检索
Hinton第15课,本节有课外读物<Semantic Hashing>和<Using Very Deep Autoencoders for Content-Based Image ...
- 前端备忘录 — IE 的条件注释
CSS hack 由于不同厂商的浏览器,比如 Internet Explorer,Safari,Mozilla Firefox, Chrome 等,或者是同一厂商的浏览器的不同版本,如 IE6 和 I ...
- 理解Android安全机制
本文从Android系统架构着手,分析Android的安全机制以SE Android,最后给出一些Android安全现状和常见的安全解决方案. 1.Android系统架构 Android采用分层的系统 ...