2017.10.21 C组比赛总结
今天考得不太好,只拿了100+0+0+30=130分。。。
【GDKOI训练】音乐节拍
考场AC了!
其实就是大水一道!
思路:二分查找
每次输入后,输出该时刻所在的区间的编号就好了。
总体难度:★★☆☆☆
【GDKOI训练】电视游戏问题##
思路:捆绑背包
设f[i,j]为前i个平台用j钱的最大价值。
然后一边输入一遍DP就好了。
具体过程请看下面的代码~~
总体难度:★★★★☆
【GDKOI训练】头晕的奶牛##
思路:拓扑排序 ←(不懂的戳这里)
拓扑排序后,对于每条双向边,排序后位置靠前的先输出即可。
拓扑排序可以用BFS实现(不用管双向边)。
每连通到一个以前没到过的点,都把它存进队列里,并把它连到的所有边擦掉(所连接的点入度-1),再把这个点从图上永远擦去!
总体难度:★★★☆☆
【GDKOI训练】过路费##
变形的最短路算法。
思路:Floyd(DP)
用一个数组表示边值,一个数组表示点值,然后每次都把两个数组的值加起来判断就可以了。
只用做4次Floyd就可以了(卡常数,嘿嘿嘿嘿)
总体难度:★★☆☆☆
总结:这次比赛的质量还是挺高的。
终于不是那种简单到用暴力水法就可以AK的题目了(然而我还是A了)
我还是要学一下怎样做难题吧!
Σ(`д′*ノ)ノ
代码
音乐节拍
#include<cstdio>
using namespace std;
struct notes
{
int start,end;
}a[50010];
int main()
{
freopen("mnotes.in","r",stdin);
freopen("mnotes.out","w",stdout);
int l,r,n,k,i,j,mid,next=0,b;
scanf("%d%d",&n,&k);
for(i=1;i<=n;i++)
{
scanf("%d",&b);
a[i].start=next,a[i].end=next+b-1;
next=next+b;
}
for(i=1;i<=k;i++)
{
scanf("%d",&b);
l=1,r=n;
while(l<=r)
{
mid=(l+r)/2;
if(a[mid].start<=b&&a[mid].end>=b) break;
if(a[mid].start>b) r=mid-1;
else if(a[mid].end<b) l=mid+1;
}
printf("%d\n",mid);
}
return 0;
}
电视游戏问题
#include<cstdio>
#include<cstring>
using namespace std;
__attribute__((optimize("-O2"))) //代码加速!!!
int n,m,f[51][100001];
__attribute__((optimize("-O2")))
int max(int x,int y)
{
if(x>y) return x;
else return y;
}
__attribute__((optimize("-O2")))
int main()
{
freopen("vidgame.in","r",stdin);
freopen("vidgame.out","w",stdout);
int i,j,k,t,ans=0,x,y,use,num,money,milk;
scanf("%d%d",&n,&m);
for(i=1;i<=n;i++)
{
scanf("%d%d",&use,&num);
for(j=use;j<=m;j++) f[i][j]=f[i-1][j-use];
for(j=1;j<=num;j++)
{
scanf("%d%d",&money,&milk);
for(k=m;k>=use+money;k--)
{
f[i][k]=max(f[i][k],f[i][k-money]+milk);
}
}
for(j=0;j<=m;j++) f[i][j]=max(f[i-1][j],f[i][j]);
}
for(i=1;i<=m;i++) if(f[n][i]>ans) ans=f[n][i];
printf("%d\n",ans);
return 0;
}
头晕的奶牛
#include<cstdio>
using namespace std;
int a[100010],lian[100010][110],b[100010],date[100010];
__attribute__((optimize("-O2")))
int main()
{
freopen("dizzy.in","r",stdin);
freopen("dizzy.out","w",stdout);
int n,m1,m2,i,j,k,x,y,head=0,tail=0;
scanf("%d%d%d",&n,&m1,&m2);
for(i=1;i<=m1;i++)
{
scanf("%d%d",&x,&y);
lian[x][++lian[x][0]]=y;
a[y]++;
}
for(i=1;i<=n;i++)
{
if(!a[i])
{
tail++;
date[tail]=i;
b[i]=tail;
}
}
while(head<tail)
{
head++;
k=date[head];
for(i=1;i<=lian[k][0];i++)
{
j=lian[k][i];
a[j]--;
if(!a[j])
{
tail++;
date[tail]=j;
b[date[tail]]=tail;
}
}
}
for(i=1;i<=m2;i++)
{
scanf("%d%d",&x,&y);
if(b[x]>b[y]) printf("%d %d\n",y,x);
if(b[x]<b[y]) printf("%d %d\n",x,y);
}
return 0;
}
过路费
#include<cstdio>
using namespace std;
int a[100010],lian[100010][110],b[100010],date[100010];
__attribute__((optimize("-O2")))
int main()
{
freopen("dizzy.in","r",stdin);
freopen("dizzy.out","w",stdout);
int n,m1,m2,i,j,k,x,y,head=0,tail=0;
scanf("%d%d%d",&n,&m1,&m2);
for(i=1;i<=m1;i++)
{
scanf("%d%d",&x,&y);
lian[x][++lian[x][0]]=y;
a[y]++;
}
for(i=1;i<=n;i++)
{
if(!a[i])
{
tail++;
date[tail]=i;
b[i]=tail;
}
}
while(head<tail)
{
head++;
k=date[head];
for(i=1;i<=lian[k][0];i++)
{
j=lian[k][i];
a[j]--;
if(!a[j])
{
tail++;
date[tail]=j;
b[date[tail]]=tail;
}
}
}
for(i=1;i<=m2;i++)
{
scanf("%d%d",&x,&y);
if(b[x]>b[y]) printf("%d %d\n",y,x);
if(b[x]<b[y]) printf("%d %d\n",x,y);
}
return 0;
}
2017.10.21 C组比赛总结的更多相关文章
- 2017.10.28 C组比赛总结
这次比赛有点坑... [GDKOI2004]石子游戏 方法:判断奇偶性 输入n 如果n是奇数,输出 xiaoshi 如果n是偶数,输出 xiaoyong 比赛得分:30 错因:找错规律了(忘记了两个人 ...
- 2017.9.23 C组比赛总结
今天又回到了C组,感觉爽歪歪~分数终于是个三位数了,yes! 第一题,赛车.水!只用一个贪心就可以AC了. first,以速度为关键字小到大qsort一下... scond,枚举每一个赛车,看看它可以 ...
- 2017.10.21 Java中的数据源与连接池技术
1.数据源技术就是预先建立好一定的数量的数据库连接,并将这些连接保存在连接池中,有连接池负责对这些数据库连接管理,当访问数据库时,只需要从连接池中取出有空闲状态的数据库连接:当程序访问数据库结束时,释 ...
- 2017/10 冲刺NOIP集训记录:暁の水平线に胜利を刻むのです!
前几次集训都没有记录每天的点滴……感觉缺失了很多反思的机会. 这次就从今天开始吧!不能懈怠,稳步前进! 2017/10/1 今天上午进行了集训的第一次考试…… 但是这次考试似乎是近几次我考得最渣的一次 ...
- 第9次Scrum会议(10/21)【欢迎来怼】
一.小组信息 队名:欢迎来怼小组成员队长:田继平成员:李圆圆,葛美义,王伟东,姜珊,邵朔,冉华小组照片 二.开会信息 时间:2017/10/21 17:20~17:45,总计25min.地点:东北师范 ...
- 2016.9.10初中部上午NOIP普及组比赛总结
2016.9.10初中部上午NOIP普及组比赛总结 链接:https://jzoj.net/junior/#contest/home/1340 好不爽!翻车了!不过排名差不多在中间偏上一点, 还好不是 ...
- 2016.10.7初中部上午NOIP普及组比赛总结
2016.10.7初中部上午NOIP普及组比赛总结 这次的题还可以,重新入了比赛的前十. 进度: 比赛:90+10+70+30=200 改题:AC+AC+AC+AC=AK 找试场 这题很简单,但是被欺 ...
- 2016.10.6初中部上午NOIP普及组比赛总结
2016.10.6初中部上午NOIP普及组比赛总结 中了病毒--病毒--病毒-- 进度: 比赛:AC+0+0+20=120 改题:AC+0+AC+20=220 Stairs 好--简--单!递推就过了 ...
- 2016.10.5初中部上午NOIP普及组比赛总结
2016.10.5初中部上午NOIP普及组比赛总结 这次的题目出得挺有质量的.但我觉得我更应该努力了. 进度: 比赛:0+20+0+0=20 改题:AC+AC+AC+AC=AK kk的作业 这题我错得 ...
随机推荐
- hdu 3572 仪器与任务 最大流 好题 体会建图思想
Task Schedule Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
- 应对高并发场景的redis加锁技巧
// 获取锁getLock() { // 是否有正在执行的线程 boolean hasLock = false; try { hasLock = redisClient ...
- Java常考面试题整理(二)
21.Iterator和ListIterator的区别是什么? 参考答案: 下面列出了他们的区别: Iterator可以用来遍历Set和List集合,但是ListIterator只能用来遍历List. ...
- C++入门经典-例2.11-流输出小数控制
1:代码如下: // 2.11.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> usin ...
- LeetCode82----删除排序链表中的重复元素 II
给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中 没有重复出现 的数字. 示例 1: 输入: 1->2->3->3->4->4->5 输出: 1-&g ...
- java基本类型对齐
1.Java 基本数据类型和精度 整数数据类型 关键字 描述 大小 格式 byte 字节长度整数 8 位二进制补码 从 +127 到 -128 short 短整型 16 位二进制补码 从 +32767 ...
- [论文理解] Learning Efficient Convolutional Networks through Network Slimming
Learning Efficient Convolutional Networks through Network Slimming 简介 这是我看的第一篇模型压缩方面的论文,应该也算比较出名的一篇吧 ...
- leetcode-easy-dynamic-198 House Robber-NO
mycode 思路: a:1 2 3 4 5 6 7 8 9 f(9) =max( f(7) + a9 ,f(8)) 前一步.前两步 至于前三步 f(9) = f(6)+ a9,但其实f(7)在求值的 ...
- UVA 1025 -- A Spy in the Metro (DP)
UVA 1025 -- A Spy in the Metro 题意: 一个间谍要从第一个车站到第n个车站去会见另一个,在是期间有n个车站,有来回的车站,让你在时间T内时到达n,并且等车时间最短, ...
- leetcode 148排序链表
优先队列容器,使用小顶堆排序:timeO(nlogn) spaceO(n) /** * Definition for singly-linked list. * struct ListNode { * ...