第十届山东省acm省赛补题(1)
今天第一场个人训练赛的题目有点恐怖啊,我看了半个小时多硬是一道都不会写。我干脆就直接补题去了。。。。
先补的都是简单题,难题等我这周末慢慢来吧。。。
A Calandar
Time Limit: 1 Second Memory Limit: 65536 KB
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4113
题目意思很明确:给出一个日期和对应的星期几,求出另一个所给的日期是星期几。
题目已经简化了,12个月,每月30天,一周5天,注意一下。
然而在补题的时候,我wa了好几发。。理了一下思路后,重写了以下a了。
虽说是签到题,但需要注意的有两点,一个是取模后需要注意为0的情况,一个是小于零的情况。
代码如下:
#include <iostream>
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
string Q[]={"","Monday", "Tuesday", "Wednesday", "Thursday" ,"Friday"};
int main()
{
int T;
cin>>T;
while(T--)
{
string s;
ll y1,m1,d1,y2,m2,d2,k;
cin>>y1>>m1>>d1>>s>>y2>>m2>>d2;
ll dt=(y2-y1)*+(m2-m1)*+d2-d1;
dt=dt%;
if (dt<) dt+=;
for (int i=; i<=; i++)
{
if (Q[i]==s)
k=i;
}
k+=dt;
if (k%==) k=;
else k=k%;
cout<<Q[k]<<endl;
}
return ;
}
C Wandering Robot
Time Limit: 1 Second Memory Limit: 65536 KB
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4115
题意:机器人从原点按指令走,整个过程距离原点最远距离是多少,距离定义为abs(x1-x2)+abs(y1-y2)
一开始考虑的是最远是在第k次,后来发现不对,例如下面这组样例:
7 2
UUUDDDD
所以比较一下第一次和第k次哪个远就好了,中间的次数按周期算,1和k模拟就好
代码如下:
#include <iostream>
#include <bits/stdc++.h> using namespace std;
typedef long long ll; int main()
{
int T;
cin>>T;
while (T--)
{
string s;
ll n,k,x=,y=,ma1=-,ma2=-,ans;
scanf("%lld%lld",&n,&k);
cin>>s;
s=""+s;
for (int i=; i<=n; i++)
{
if (s[i]=='U') y++;
else if (s[i]=='D') y--;
else if (s[i]=='L') x--;
else if (s[i]=='R') x++;
ll cur=abs(x)+abs(y);
if (cur>ma1) ma1=cur;
}
x*=k-;
y*=k-;
for (int i=; i<=n; i++)
{
if (s[i]=='U') y++;
else if (s[i]=='D') y--;
else if (s[i]=='L') x--;
else if (s[i]=='R') x++;
ll cur=abs(x)+abs(y);
if (cur>ma2) ma2=cur;
}
if (ma1>ma2) ans=ma1;
else ans=ma2;
printf("%lld\n",ans);
}
return ;
}
D Game on a Graph
Time Limit: 1 Second Memory Limit: 65536 KB
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4116
比赛的时候这道题我没看,队友敲的;
题意大概是说:有k个人玩游戏,分成1,2两组。游戏初始给出一个简单无向连通图,k个人周期依次操作,每次拿走一条边,仍然要保证图的联通,当取无边可取时(即目前状态取走任意一条边就会使图不再连通),该玩家所在的小组输掉游戏,游戏结束,输出赢家。
一开始觉得跟图的连通性有关,后来发现根本没有。保证n个点相连至少需要n-1条边,只需要求出可以去除几条边就完全可以了。同样注意取模后为0的情况,其他细节看代码吧。
代码如下:
#include <iostream>
#include <bits/stdc++.h> using namespace std;
typedef long long ll;
const int maxn=1e5+;
char a[maxn];
int main()
{
int T;
cin>>T;
while (T--)
{
ll k,n,m;
scanf("%lld",&k);
scanf("%s",a+);
scanf("%lld%lld",&n,&m);
for (int i=; i<=m; i++)
{
int x,y;
scanf("%d%d",&x,&y);
}
ll ov=m-n+;
ov%=k;
if (a[ov+]=='') printf("2\n");
else printf("1\n");
}
return ;
}
F Stones in the Bucket
Time Limit: 1 Second Memory Limit: 65536 KB
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4118
这个题我敲了一半,然后队友接手直接过了,也不是很难;
题意:给你n堆石子,求出最少几次操作使得所有石子堆的石子个数相同。操作分两种:1。扔一个。 2。把一个石子从一堆移动到另一堆。
先判断需要扔的情况,注意扔的时候需要从最多的那一堆开始扔。
移动情况就是每堆与平均值的差了,记得除以2就行。
代码如下:
#include <iostream>
#include <bits/stdc++.h> using namespace std;
typedef long long ll;
const int maxn=1e5+;
ll a[maxn];
bool cmp(ll x,ll y)
{
return x>y;
}
int main()
{
int T;
cin>>T;
while (T--)
{
ll n,sum=,ave=,ans=;
scanf("%lld",&n);
for (int i=; i<=n; i++)
scanf("%lld",&a[i]),sum+=a[i];
ave=sum/n;
ll ov=sum-ave*n,t;
t=ov;
sort(a+,a++n,cmp);
for (int i=; i<=n; i++)
{
if (ov<=) break;
ll dt=a[i]-ave;
if (ov>=dt)
{
ov-=dt;
a[i]=ave;
}
else
{
a[i]-=ov;
ov=;
break;
}
}
for (int i=; i<=n; i++)
ans+=abs(a[i]-ave);
ans/=;
ans+=t;
printf("%lld\n",ans);
}
return ;
}
M Sekiro
Time Limit: 1 Second Memory Limit: 65536 KB
题意很简单:死一次丢一半钱,n元钱,死k次,还剩多少?
注意特判。
代码如下:
#include <iostream>
#include <bits/stdc++.h> using namespace std;
typedef long long ll; int main()
{
int T;
cin>>T;
while (T--)
{
ll n,k;
scanf("%lld %lld",&n,&k);
if (k>) k=;
while(k--)
{
if (n==||n==) break;
if (n%==) n/=;
else n=n/+;
}
printf("%lld\n",n);
}
return ;
}
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4125
先写到这里吧。剩下的晚点补完!
5.17 补充 翻看ppt时,发现传递闭包那个题还可以bitset优化 改成 a[i][j]|=(a[i][k]&&a[k][j]);
优化后50ms-》30ms
第十届山东省acm省赛补题(1)的更多相关文章
- 第十届山东省acm省赛补题(2)
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4124 L Median Time Limit: 1 Second ...
- 第七届山东省ACM省赛
激动人心的省赛终于结束了…平静下来再回头看真的感觉一波三折…先是赛前毫无预兆的查出突发性耳聋…伴随而来的就是左耳听力下降.轻微耳鸣.极个别情况下的头晕…不过这都还好,毕竟药物可以恢复…热身赛只过了一道 ...
- 2018年第九届山东省ACM省赛总结
去年打完区域赛之后,面对着两个队友都去找实习的情况,我自己对今年省赛还是有点慌的.不只一次的像我的队友说明自己很慌,但是老曹跟会长都说:“没事,慌啥!”前几场训练赛因为老曹跟秋洁有面试有时候只能一个人 ...
- 哈尔滨工程大学ACM预热赛 补题
链接:https://ac.nowcoder.com/acm/contest/554/A来源:牛客网 小虎刚刚上了幼儿园,老师让他做一个家庭作业:首先画3个格子,第二行有2个格子,第三行有1个格子. ...
- 2018山东省ACM省赛G题-Game
Alice and Bob are playing a stone game. There are n piles of stones. In each turn, a player can remo ...
- 第十届蓝桥杯省赛JavaB组个人题解
前言 以下的第十届蓝桥杯Java B组省赛的题目题解只是我个人的题解,提供一些解题思路,仅作参考,如有错误,望大家指出,不甚感激,我会及时更改. 试题 A: 组队 ----- 答案:490 [问题描述 ...
- 2019山东省ACM省赛菜鸡的赛后总结
省赛总结 2019-05-13 21:27:40 虽然第一次就死的这么难看,但是的确发现了很多问题,我想这是未来我和我的队友要解决的,而不是去难过,去感慨自己是有多菜.在大一训练结束马上参加暑假集训的 ...
- 2017河工大校赛补题CGH and 赛后小结
网页设计课上实在无聊,便开始补题,发现比赛时候僵着的东西突然相通了不少 首先,"追妹"这题,两个队友讨论半天,分好多种情况最后放弃(可是我连题目都没看啊),今天看了之后试试是不是直 ...
- “浪潮杯”第九届山东省ACM大学生程序设计竞赛重现赛 C-Cities
题目描述:There are n cities in Byteland, and the ith city has a value ai. The cost of building a bidirec ...
随机推荐
- ubuntu 配置smb后无法访问
配置如下 [/gscloud] path = /gscloud browseable = yes writable = yes guest ok = yes read only = no create ...
- 深入理解JAVA虚拟机 虚拟机字节码执行引擎
执行引擎 执行引擎是java虚拟机的重要组成部分.它的作用是接收字节码,解析字节码,执行并输出执行结果. 虚拟机是相对于物理机的概念,物理机的执行引擎是直接建立在处理器.寄存器.指令集和操作系统的层面 ...
- 2018 ACM-ICPC 区域赛(青岛站)题解整理
题目链接 C - Flippy Sequence(组合数学+分类讨论) 两区间异或一下,分段考虑,如果全为0则任选两相同区间,答案为$C_{n+1}^{2}=\frac{n(n+1)}{2}$,只有一 ...
- 上传base64图片到七牛云前端遇到的坑
介意前端普通引入七牛云SDk上传图片到七牛云需要多个js,所以才有了base64的上传方式,简化操作,(懒.) 七牛云官方文档如下 https://developer.qiniu.com/kodo/k ...
- jQuery后续和 前端框架Bootstrap
目录 一.jQuery后续 1. 动画效果 (1)自定义点赞动画实例 2. jQuery的自带方法 (1)each (类似for循环) (2)data() (存放隐形的数据) 二.前端框架之Boots ...
- ESP8266-模拟输出(PWM)
PWM(Pulse Width Modulation,脉宽调制),是在保持波的频率不变的同时改变脉宽的技术 首先,我们来理解一下占空比.一个脉冲周期由一个ON周期(VCCC)和一个OFF周期(GND) ...
- 【NOIP2014模拟11.3】噪音
题目 FJ有M个牛棚,编号1至M,刚开始所有牛棚都是空的.FJ有N头牛,编号1至N,这N头牛按照编号从小到大依次排队走进牛棚,每一天只有一头奶牛走进牛棚.第i头奶牛选择走进第p[i]个牛棚.由于奶牛是 ...
- 记第一次正式线上笔试(Tencent——正式考-技术研发类-综合-2018实习生招聘)
选择题做的跟傻逼一样,不多说了..大学只打了ACM还不是计算机科班出身的我,连好多名词都不认识..... 三道编程题很简单,下面给出三道题的大致题意以及题解. 1.给出n和m,满足(2m)可以整除n. ...
- mobx使用
1.mobx状态管理 安装:creact-react-app mobx action.store.reducer. action是一个函数,事件调用actions直接修改state,Actions是唯 ...
- windows10 下 gcc/g++ 的安装
一.gcc的下载 网址:www.mingw.org ,点击右上方的 download installer 二.安装 打开安装程序,默认安装,弹出下列界面 找到mingw32-gcc-g++(注意cla ...