ICPC训练周赛 Benelux Algorithm Programming Contest 2019
D. Wildest Dreams
这道题的意思是Ayna和Arup两人会同时在车上一段时间,在Ayna在的时候,必须单曲循环Ayna喜欢的歌,偶数段Ayna下车,若此时已经放了她喜欢的那首歌,就要将它放完,然后按照顺序播放其他的歌,输出一共播放了Ayna喜欢的歌多少分钟。
分情况考虑,加起来总和就是一共播放的时间。
做题思路:
一:奇数段的时间总和;
二:判断奇数段的时间Ayna喜欢的歌是否恰好播放完:
(1)若恰好播放完,对其后的偶数段不做处理
(2)若否,判断偶数段时间是否大于此歌未播放部分的时间:
a.若小于等于,直接加上偶数时间段,并将该偶数段归零
b.若大于,将偶数时间段减去此歌未播放部分的时间
三:将处理过的偶数段的时间进行计算,一共循环列表几次,判断是否恰好循环整列表
(1)是,总和只加上循环次数乘以这首歌单曲播放完毕的时间
(2)否,判断剩余时间长度是否包含Ayna喜欢的歌,若包含,总和加上循环次数乘以这首歌单曲播放完毕的时间+播放这首歌的时间
AC代码:
#include<cstdio>
#include<algorithm>
#include<iostream>
#include <cstring>
using namespace std;
int main()
{
int cd,i;
cin>>cd;
for(int k=1;k<=cd;k++)
{ int sum2=0;
cout<<"CD #"<<k<<":"<<endl;
int cds,f;
int a[25];
cin>>cds>>f;
for(i=0;i<cds;i++){
cin>>a[i];
sum2+=a[i];
}
int n;
cin>>n;
int sum=0;
cin>>m;
int b[25];
for(i=0;i<m;i++){
cin>>b[i];
}
for(i=0;i<m;i++){
if(i%2==0){
sum+=b[i];
}
if(i%2==1){
int sheng=b[i-1]%a[f-1];
if(sheng!=0){
b[i]-=a[f-1]-sheng;
if(b[i]>0){
sum+=a[f-1]-sheng;
}else{
sum+=b[i]+a[f-1]-sheng;
b[i]=0;
}
}
sheng=b[i]/sum2;
sum+=sheng*a[f-1];
sheng=b[i]%sum2;
if(sheng-sum2+a[f-1]>0){
sum+=sheng-sum2+a[f-1];
}
}
}
cout<<sum<<endl;
}
cout<<endl;
}
return 0;
}
B. Phoneme Palindromes
这道题的意思是根据输入的p对认为相等的字母,判断输入的字符串是否为回文。
做题思路:
利用<map>建立两个字母的对应,这样就将所有可以相互替换的字母都统一替换成相同字母,然后判断是否回文即可。
AC代码:
#include<iostream>
#include<cstring>
#include<map>
using namespace std;
int main(){
int n,p,q,i,j,m,x,y;
char a,b,s[100];
cin>>n;
for(i=1;i<=n;i++){
cout<<"Test case #"<<i<<":" <<endl;
cin>>p;
map<char,char>mp;
for(j=0;j<26;j++)
{
char c='a'+j;
mp[c]=c;
}
for(j=0;j<p;j++){
cin>>a>>b;
mp[a]=mp[b]=a;
}
cin>>q;
for(j=0;j<q;j++){
cin>>s;
cout<<s<<" ";
m=strlen(s);
int p=0;
for(x=0;x<m;x++){
s[x]=mp[s[x]];
}
for(x=0;x<=m/2;x++){
if(s[x]!=s[m-x-1]){
p=1;
break;
}
}
if(p==0){
cout<<"YES"<<endl;
}
else{
cout<<"NO"<<endl;
}
}
cout<<endl;
}
return 0;
}
ICPC训练周赛 Benelux Algorithm Programming Contest 2019的更多相关文章
- 2020.3.21--ICPC训练联盟周赛Benelux Algorithm Programming Contest 2019
A Appeal to the Audience 要想使得总和最大,就要使最大值被计算的次数最多.要想某个数被计算的多,就要使得它经过尽量多的节点.于是我们的目标就是找到 k 条从长到短的链,这些链互 ...
- ICPC训练联盟周赛Preliminaries for Benelux Algorithm Programming Contest 2019
I题 求 a 数组平方的前缀和和求 a 数组后缀和,遍历一遍即可 AC代码 #include<iostream>#include<cmath>using namespace s ...
- 03.14 ICPC训练联盟周赛,Preliminaries for Benelux Algorithm Programming Contest 2019
A .Architecture 题意:其实就是想让你找到两行数的最大值,然后比较是否相同,如果相同输出'possible',不同则输出'impossible' 思路:直接遍历寻找最大值,然后比较即可 ...
- 2020.3.14--训练联盟周赛 Preliminaries for Benelux Algorithm Programming Contest 2019
1.A题 题意:给定第一行的值表示m列的最大值,第m行的值表示n行的最大值,问是否会行列冲突 思路:挺简单的,不过我在一开始理解题意上用了些时间,按我的理解是输入两组数组,找出每组最大数,若相等则输出 ...
- Benelux Algorithm Programming Contest 2019
J. Jazz it Up!题目要求,n*m的因子中不能含有平方形式,且题目中已经说明n是一个无平方因子的数, 那么只要m是无平方因子的数,并且n和m没有共同的因子即可.要注意时间复杂度!代码:#in ...
- Preliminaries for Benelux Algorithm Programming Contest 2019
A. Architecture 如果行最大值中的最大值和列最大值中的最大值不同的话,那么一定会产生矛盾,可以手模一个样例看看. 当满足行列最大值相同条件的时候,就可以判定了. 因为其余的地方一定可以构 ...
- Benelux Algorithm Programming Contest 2014 Final(第二场)
B:Button Bashing You recently acquired a new microwave, and noticed that it provides a large number ...
- 2014 Benelux Algorithm Programming Contest (BAPC 14)E
题目链接:https://vjudge.net/contest/187496#problem/E E Excellent Engineers You are working for an agency ...
- 计蒜客 28319.Interesting Integers-类似斐波那契数列-递推思维题 (Benelux Algorithm Programming Contest 2014 Final ACM-ICPC Asia Training League 暑假第一阶段第二场 I)
I. Interesting Integers 传送门 应该是叫思维题吧,反正敲一下脑壳才知道自己哪里写错了.要敢于暴力. 这个题的题意就是给你一个数,让你逆推出递推的最开始的两个数(假设一开始的两个 ...
随机推荐
- JUC-八锁现象和不安全锁
1,被 synchronized 修饰的方法,锁的对象是方法的调用者(实例对象) 2,被 static 修饰的方法,锁的对象就是 Class模板对象,这个则全局唯一 问题7: 一个普通同步方法,一个静 ...
- 纯CSS实现元素垂直水平居中-非固定宽度
这里不讨论行内元素的居中!! 盒子垂直居中+水平居中的需求时经常遇到的,看到的较多实现逻辑是固定content-box的宽度,通过让margin-left和margin-top等于宽或高的负一半来实现 ...
- javascript的装饰者模式Decorator
刚开始看这段代码有点绕,现在回过头来看,so easy! Function.prototype.before = function(beforefn){ var _self = this; retur ...
- java算法--链表
虽然这个文章看着很多,但是大多是对于细节的讲解,如果想要快速了解,可以直接观看末尾代码.上面的代码内容都是来自于文章末尾的代码. 很重要的算法,也是比较简单的算法. 但是在java中,因为不存在c和c ...
- 智慧港口——基于二三维一体化GIS的港口可视化监管平台
“智慧港口”是以现代化基础设施设备为基础,以云计算.大数据.物联网.移动互联网.智能控制等新一代信息技术与港口运输业务深度融合为核心,以港口运输组织服务创新为动力,以完善的体制机制.法律法规.标准规范 ...
- Mathtype快捷键&小技巧
Mathtype使用方便,能插入到Office等编辑器中,Latex公式在某些地方更加通用,如网页和书籍. 1. Mathtype简介 数学公式编辑器(MathType)是一款专业的数学公式编辑工具, ...
- git 查看commit的提交记录
相关命令: git log 查看所有提交记录 git show 查看提交详情 示例: git log: git show: 查看指定commit的详情:git show commitId 查看某次c ...
- vue缓存当前路由(在输入框中输入信息后,跳转其他路由再回来,仍可看到刚刚输入的内容等)
缓存路由页面的当前状态: <transition name="fade" mode="out-in"> <keep-alive> & ...
- [转]【maven】解决Missing artifact jdk.tools:jdk.tools:jar:1.6
解决在pom.xml文件中出现的Missing artifact jdk.tools:jdk.tools:jar:1.6问题 <dependency> <groupId>jdk ...
- JavaScript 模式》读书笔记(4)— 函数1
从这篇开始,我们会用很长的章节来讨论函数,这个JavaScript中最重要,也是最基本的技能.本章中,我们会区分函数表达式与函数声明,并且还会学习到局部作用域和变量声明提升的工作原理.以及大量对API ...