2013 CSU校队选拔赛(1) 部分题解
A: Decimal
Time Limit: 1 Sec Memory Limit: 128 MB
Submit: 99
Solved: 10
[
Submit][
Status][
Web Board]
Description
任意一个分数都是有理数,对于任意一个有限小数,我们都可以表示成一个无限循环小数的形式(在其末尾添加0),对于任意一个无限循环小数都可以转化成一个分数。现在你的任务就是将任意一个无限循环小数转化成既约分数形式。所谓既约分数表示,分子和分母的最大公约数是1。
Input
有多组数据。
每组数据一行。输入为0.a1a2a3...ak(b1b2...bm)的形式,其中a1a2a3...ak为非循环部分,(b1b2b3..bm)为循环部分。数据保证k和m不会超过8.注意长度可能为0哦!
Output
对于每组测试数据输出A/B,其中A是分子,B是分母,A,B均为整数,gcd(A, B) = 1.
Sample Input
Sample Output
HINT http://172.16.0.11/JudgeOnline/problem.php?id=1008
#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<string.h>
#include<queue>
#include<stack>
#include<set>
#define oo 1000000007
#define ll long long
#define MAXN 2005
using namespace std;
int a;
struct node
{
int d,t;
bool operator<(node A) const
{
if (A.t!=t) return A.t<ts;
return d<A.d;
}
}h;
priority_queue<node> QA;
int ans[MAXN];
int main()
{
int n,k,b,Q,x,i,sum,num;
while (~scanf("%d%d%d%d",&n,&k,&a,&b))
{
while (!QA.empty()) QA.pop();
num=0;
for (i=1;i<=n;i++)
{
scanf("%d",&x);
if (x<=k) h.d=x,h.t=0,QA.push(h);
else num++;
}
for (int times=1;times<=205;times++)
{
ans[times]=num;
if (num>0) h.d=0,h.t=times-1,QA.push(h),num--;
while (!QA.empty())
{
h=QA.top();
if (h.d+(times-h.t)*a<=k) break;
QA.pop(),num++;
}
}
scanf("%d",&Q);
while (Q--)
{
scanf("%d",&x);
printf("%d\n",ans[x]);
}
}
return 0;
}
C: Substring
Time Limit: 4 Sec
Memory Limit: 10 MB
Submit: 100
Solved: 11
[
Submit][
Status][
Web Board]
Description
Given a string s. The length of s is smaller than 1000.You are to caculate the number of different substrings of s.
Input
There are multiple test cases.
Each test case contains one line, with a string s.You may assume that s only contains
lowercase letters. You may assume that there are only ten test cases with the length of string s is bigger than 400.
Output
For each test case, you are only to output one integer, the answer.
Sample Input
Sample Output
HINT http://172.16.0.11/JudgeOnline/problem.php?id=1010
#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<string.h>
#include<queue>
#include<map>
#include<stack>
#include<set>
#define oo 1000000007
#define MAXN 1005
using namespace std;
struct node
{
map<int,int> son;
};
map<int,node>P;
char s[MAXN];
vector<int> A[26];
int main()
{
int len,ans,num,i,j,h,x;
while (~scanf("%s",s))
{
len=strlen(s);
for (i=0;i<26;i++) A[i].clear();
for (i=0;i<len;i++)
A[s[i]-'a'].push_back(i);
ans=0;
for (int t=0;t<26;t++)
{
P.clear(),P[0].son.clear(),num=0;
for (i=A[t].size()-1;i>=0;i--)
{
h=0;
for (j=A[t][i];j<len;j++)
{
x=s[j]-'a';
if (!P[h].son[x])
P[h].son[x]=++num,ans++,
P[num].son.clear();
h=P[h].son[x];
}
}
}
printf("%d\n",ans);
}
return 0;
}
D: Manor
Time Limit: 1 Sec
Memory Limit: 128 MB
Submit: 14
Solved: 3
[
Submit][
Status][
Web Board]
Description
Input
Output
对于每一个询问m,输出第m次操作前集合B中元素的个数。
Sample Input
10 25
Sample Output
HINT http://172.16.0.11/JudgeOnline/problem.php?id=1011
#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<string.h>
#include<queue>
#include<stack>
#include<set>
#define oo 1000000007
#define ll long long
#define MAXN 2005
using namespace std;
int a;
struct node
{
int d,t;
bool operator<(node A) const
{
if (A.t!=t) return A.t<ts;
return d<A.d;
}
}h;
priority_queue<node> QA;
int ans[MAXN];
int main()
{
int n,k,b,Q,x,i,sum,num;
while (~scanf("%d%d%d%d",&n,&k,&a,&b))
{
while (!QA.empty()) QA.pop();
num=0;
for (i=1;i<=n;i++)
{
scanf("%d",&x);
if (x<=k) h.d=x,h.t=0,QA.push(h);
else num++;
}
for (int times=1;times<=205;times++)
{
ans[times]=num;
if (num>0) h.d=0,h.t=times-1,QA.push(h),num--;
while (!QA.empty())
{
h=QA.top();
if (h.d+(times-h.t)*a<=k) break;
QA.pop(),num++;
}
}
scanf("%d",&Q);
while (Q--)
{
scanf("%d",&x);
printf("%d\n",ans[x]);
}
}
return 0;
}
E: City Tour
Time Limit: 1 Sec
Memory Limit: 128 MB
Submit: 64
Solved: 12
[
Submit][
Status][
Web Board]
Description
Alice想要从城市A出发到城市B,由于Alice最近比较穷(不像集训队陈兴老师是个rich second),所以只能选择做火车从A到B。不过Alice很讨厌坐火车,火车上人比较多,比较拥挤,所以Alice有很严格的要求:火车的相邻两站间的最大距离尽可能的短,这样Alice就可以在停站的时候下车休息一下。当然Alice希望整个旅途比较短。
Input
Output
对于每组测试数据输出满足Alice要求的从A到B的最短距离。
Sample Input
3 50
Sample Output
HINT http://172.16.0.11/JudgeOnline/problem.php?id=1012
#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<string.h>
#include<queue>
#include<stack>
#include<set>
#define oo 1000000007
#define MAXN 1005
#define MAXM 100005
using namespace std;
struct node
{
int y,d,next;
}line[MAXM];
int Lnum,_next[MAXN];
void addline(int x,int y,int d)
{
line[++Lnum].next=_next[x],_next[x]=Lnum,line[Lnum].y=y,line[Lnum].d=d;
}
queue<int> Q;
int dis[MAXN];
bool inqueue[MAXN];
int SPFA(int s,int e,int M)
{
while (!Q.empty()) Q.pop();
memset(inqueue,false,sizeof(inqueue));
memset(dis,-1,sizeof(dis));
dis[s]=0,Q.push(s);
while (!Q.empty())
{
int h=Q.front();
Q.pop();
inqueue[h]=false;
for (int k=_next[h];k;k=line[k].next)
if (line[k].d<=M)
{
int y=line[k].y;
if (dis[y]==-1 || dis[y]>dis[h]+line[k].d)
{
dis[y]=dis[h]+line[k].d;
if (!inqueue[y])
{
inqueue[y]=true;
Q.push(y);
}
}
}
}
return dis[e];
}
int main()
{
int i,n,m,A,B;
freopen("input.txt","r",stdin);
freopen("outputx.txt","w",stdout);
while (~scanf("%d%d%d%d",&n,&m,&A,&B))
{
Lnum=0,memset(_next,0,sizeof(_next));
while (m--)
{
int x,y,d;
scanf("%d%d%d",&x,&y,&d);
addline(x,y,d),addline(y,x,d);
}
int l=0,r=10001,mid,ans;
while (r-l>1)
{
mid=l+r>>1;
if (SPFA(A,B,mid)!=-1) r=mid;
else l=mid;
}
printf("%d\n",SPFA(A,B,r));
}
return 0;
}
I: 凹凸曼和小怪兽的故事
Time Limit: 2 Sec
Memory Limit: 128 MB
Submit: 7
Solved: 2
[
Submit][
Status][
Web Board]
Description
世界末日来了,凹凸曼和小怪兽们开始进行最后一次较量!这次决战总共有n个凹凸曼和n个小怪兽,位置以坐标形式给出。因为是最后一次战斗,所以无论是哪一边都想要赢得第一场角逐,于是双方都想要找出最近的那一对凹凸曼和小怪兽,凹凸曼和小怪兽的速度分别为a和b(单位长度每秒)。不过,凹凸曼和小怪兽的智商相信有童年的童鞋们都明白,写个程序帮他们算算最早的角逐需要多长时间开始吧,凹凸曼和小怪兽遇到了就会开始角逐,凹凸曼和小怪兽会相向而行。
Input
第一行给出n,a,b三个整数(0<n<100000);
接下来的n行给出凹凸曼位置,每行两个整数x,y(0≤x,y≤1000000000);
再接下来的n行给出小怪兽位置,每行两个整数x,y(0≤x,y≤1000000000);
Output
对于每一组数据输出最短开始角逐的时间。
Sample Input
0 1
Sample Output
HINT http://172.16.0.11/JudgeOnline/problem.php?id=1016
题解:
#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<cmath>
#include<string.h>
#include<queue>
#include<stack>
#include<set>
#define oo 2000000007
#define MAXN 100005
using namespace std;
struct node
{
double x,y;
bool operator<(node a) const
{
return x<a.x;
}
}A[MAXN],B[MAXN];
int bearch(int n,double key)
{
int l=1,r=n+1,mid;
while (r-l>1)
{
mid=l+r>>1;
if (B[mid].x<key) l=mid;
else r=mid;
}
return l;
}
int main()
{
int n,i,t1,t2,v1,v2;
while (~scanf("%d%d%d",&n,&v1,&v2))
{
for (i=1;i<=n;i++) scanf("%lf%lf",&A[i].x,&A[i].y);
for (i=1;i<=n;i++) scanf("%lf%lf",&B[i].x,&B[i].y);
sort(A+1,A+1+n),sort(B+1,B+1+n);
double ans=1e+60;
for (t1=1;t1<=n;t1++)
for (t2=bearch(n,A[t1].x-ans);t2<=n && B[t2].x-A[t1].x<ans;t2++)
ans=min(ans,sqrt((A[t1].x-B[t2].x)*(A[t1].x-B[t2].x)+(A[t1].y-B[t2].y)*(A[t1].y-B[t2].y)));
printf("%.3f\n",ans/(v1+v2));
}
return 0;
}
2013 CSU校队选拔赛(1) 部分题解的更多相关文章
- Codevs 2009 大dota英雄 2013年省队选拔赛辽宁(状压DP)
2009 大dota英雄 2013年省队选拔赛辽宁 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 话说退役后的生活好无聊啊,以 ...
- Codevs 2296 仪仗队 2008年省队选拔赛山东
2296 仪仗队 2008年省队选拔赛山东 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 大师 Master 题解 题目描述 Description 作为体育委员,C君负责这次运动 ...
- HDU 4685 Prince and Princess (2013多校8 1010题 二分匹配+强连通)
Prince and Princess Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Othe ...
- HDU 4669 Mutiples on a circle (2013多校7 1004题)
Mutiples on a circle Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Oth ...
- Codevs 2449 骑士精神 2005年省队选拔赛四川
2449 骑士精神 2005年省队选拔赛四川 时间限制: 1 s 空间限制: 128000 KB 题目等级 : **大师 Master** 题目描述 Description 在一个5×5的棋盘上有12 ...
- HDU 4705 Y (2013多校10,1010题,简单树形DP)
Y Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total Submiss ...
- HDU 4704 Sum (2013多校10,1009题)
Sum Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total Submi ...
- HDU 4699 Editor (2013多校10,1004题)
Editor Time Limit: 3000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total Su ...
- HDU 4696 Answers (2013多校10,1001题 )
Answers Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total S ...
随机推荐
- 用二进制方法求两个整数的最大公约数(GCD)
二进制GCD算法基本原理是: 先用移位的方式对两个数除2,直到两个数不同时为偶数.然后将剩下的偶数(如果有的话)做同样的操作,这样做的原因是如果u和v中u为偶数,v为奇数,则有gcd(u,v)=gcd ...
- 鼠标滑轮一滚动Excel就停止工作
鼠标滑轮一滚动Excel就停止工作 问题签名: 问题事件名称:APPCRASH 应用程序名:EXCEL.EXE 应用程序版本:15.0.4420.1017 应用程序时间戳:50673286 故障模块名 ...
- 言未及之而言,谓之躁;言及之而不言,谓之隐;未见颜色而言,谓之瞽(gǔ)
前言 一个高效的团队离不开leader和组员之前,组员和组员之前的通力合作.而合作的基础便是彼此之间的商讨与协调,意见的统一,进而在达成共识的前提下行动.那么如何才能和组员达成共识呢? 和组员之间的沟 ...
- 更换Winform 皮肤(下)----完全GDI+绘制
skin皮肤和DLL程序及文件:下载 链接:http://www.cnblogs.com/DebugLZQ/archive/2013/04/15/3021659.html
- 距离变换DT
距离变换:计算区域中的每个点与最接近的区域外的点之间距离,把二值图象变换为灰度图象. 对于目标中一个点,距离变换的定义为改点与目标边界最近的距离. 目标点离边界约近则值越小,转换的点越暗:越远,值越大 ...
- 为什么我的outlook只能收信不能发信,发送测试电子邮件消息: 无法发送此邮件。请在帐户属性中验证电子邮件
链接地址:http://zhidao.baidu.com/link?url=aVIFo2aNLuHIZGZuEUataHkZp4XApHqyvbEK8ACHPhi3jwhGhM0GBAtm72AnsP ...
- eclipse如何设置成保护眼的背景色
链接地址:http://jingyan.baidu.com/article/2a138328b5d9ea074a134fc7.html 长时间的使用eclipse开发会很累吧 设置一个保护眼睛的豆沙 ...
- 个人mysql配置命令
Microsoft Windows [版本 6.1.7601]版权所有 (c) 2009 Microsoft Corporation.保留所有权利. C:\Windows\system32>cd ...
- SQL Server 基础 04 函数与分组查询数据
函数与分组查询数据 系统函数分 聚合函数.数据类型转换函数.日期函数.数学函数 . . . 1. 聚合函数 主要是对一组值进行计算,然后返回一个值. 聚合函数包括 sum(求和).avg(求平均值). ...
- 欢迎大家关注我的微信公众帐号小q机器人(xiaoqrobot)(转)
一个偶然的机会让我接触到了微信公众平台,赶紧加了几个交流群了解下相关情况,突然间发现好像全部的APP开发人员都在研究微信公众帐号的开发,而我显得有些落舞了.至于为什么热度会这么高,我想一个数字足以说明 ...