The 2018 ACM-ICPC Asia Qingdao Regional Contest(青岛网络赛)
A Live Love
水
- #include <algorithm>
- #include<cstdio>
- #include<cstring>
- using namespace std;
- typedef long long ll;
- const int inf = 0x3f3f3f3f;
- const int maxn = 1e5 + ;
- int main()
- {
- int t;
- scanf("%d", &t);
- while(t--)
- {
- int n,m;
- scanf("%d%d",&n,&m);
- if(m==){
- printf("0 0\n");
- continue;
- }
- if(n==m){
- printf("%d %d\n",n,m);
- continue;
- }
- if(n>=*m-){
- printf("%d %d\n",m,);
- continue;
- }
- for(int i=;i<=m;i++) {
- if (n - m >= (m / i + (m % i != )) - ) {
- printf("%d %d\n", m, i);
- break;
- }
- }
- }
- return ;
- }
B Red Black Tree
留坑
C Halting Problem
题意:自定义了一些程序,然后问程序会不会崩溃,也就是会不会有死循环出现
思路:队友写的,大致就是同一步不可以运行一摸一样的两次吧
- #include <algorithm>
- #include<cstdio>
- #include<cstring>
- using namespace std;
- typedef long long ll;
- const int inf = 0x3f3f3f3f;
- const int maxn = 1e5 + ;
- struct com{
- char cm[];
- int v,k;
- }prog[];
- bool vstd[][];
- int main()
- {
- int n,t;
- scanf("%d", &t);
- while(t--) {
- scanf("%d",&n);
- for(int i=;i<=n;i++){
- scanf("%s%d",prog[i].cm,&prog[i].v);
- if(prog[i].cm[]!='a'){
- scanf("%d",&prog[i].k);
- }
- }
- int r=,ins=;
- int flag=;
- memset(vstd,,sizeof(vstd));
- while(true){
- if(ins>n){
- break;
- }
- if(vstd[r][ins]){
- flag=;
- break;
- }
- switch(prog[ins].cm[]){
- case 'd'://+
- vstd[r][ins]=;
- r+=prog[ins].v;
- r%=;
- ins++;
- break;
- case 'e'://==
- vstd[r][ins]=;
- if(r==prog[ins].v){
- ins=prog[ins].k;
- }else{
- ins++;
- }
- break;
- case 'n'://!=
- vstd[r][ins]=;
- if(r!=prog[ins].v){
- ins=prog[ins].k;
- }else{
- ins++;
- }
- break;
- case 'l'://<
- vstd[r][ins]=;
- if(r<prog[ins].v){
- ins=prog[ins].k;
- }else{
- ins++;
- }
- break;
- case 'g'://>
- vstd[r][ins]=;
- if(r>prog[ins].v){
- ins=prog[ins].k;
- }else{
- ins++;
- }
- break;
- default:
- vstd[r][ins]=;
- ins++;
- break;
- }
- }
- if(flag){
- puts("Yes");
- }else{
- puts("No");
- }
- }
- return ;
- }
D Pixel Art
留坑
E Infinite Parenthesis Sequence
留坑
F Chaleur
留坑
G Couleur
留坑
H Traveling on the Axis
题意:模拟红绿灯,1过,0停,每一秒之后都会改变所有的灯的状态,1变0,0变1
思路:只需要特判第一步走的需不需要停就可以,之后走起来之后的状态都是重复进行的
- #include <algorithm>
- #include<cstdio>
- #include<iostream>
- #include<cstring>
- using namespace std;
- typedef long long ll;
- char rd[];
- ll len;
- int main()
- {
- int n,t;
- while(~scanf("%d",&t)) {
- while (t--) {
- scanf("%s", rd);
- len = strlen(rd);
- long long ans = ;
- long long tmp;
- for (ll i = ; i < len - ; i++) {
- tmp = (len - i - ) * (i + );
- if (rd[i] == rd[i + ])tmp *= ;
- ans += tmp;
- }
- //ll b=0;
- for (ll i = ; i < len; i++) {
- ans += rd[i] == '' ? (len - i) : (len - i) * ;
- //b+=rd[i]=='1'?(len-i):(len-i)*2;
- }
- cout << ans << endl;
- }
- }
- return ;
- }
I Kuririn MIRACLE
J Press the Button
题意:按灯,当灯亮的时候按压可以加分,每一次按都会重置灯的熄灭时间。
思路:可以先找到两个数的最小公倍数,然后就可以按照这个周期进行一些剪枝,在每一次周期或者是最后一次的剩余时间里可以模拟,队友用了栈写之后超时了,后来另一位队友没有用栈就AC了
- #include <algorithm>
- #include<cstdio>
- #include<iostream>
- #include<cstring>
- using namespace std;
- typedef long long ll;
- ll gcd(ll x, ll y)
- {
- return x % y == ? y : gcd(y, x % y);
- }
- int main()
- {
- int t;
- while(~scanf("%d",&t)) {
- while (t--) {
- ll a,b,c,d,v,t;
- scanf("%lld%lld%lld%lld%lld%lld",&a,&b,&c,&d,&v,&t);
- ll time=;
- ll tt=a*c/gcd(a,c);
- ll ta=a,tc=c;
- ll tans=;
- while(ta<=tt || tc<=tt){
- if(ta<=tc){
- tans+=b;
- if(ta-time>v){
- tans--;
- }
- time=ta;
- ta+=a;
- }else if(ta>tc){
- tans+=d;
- if(tc-time>v){
- tans--;
- }
- time=tc;
- tc+=c;
- }
- }
- ll sans=;ta=a,tc=c;
- time=;
- ll res=t%tt;
- while(ta<=res|| tc<=res){
- if(ta<=tc){
- sans+=b;
- if(ta-time>v){
- sans--;
- }
- time=ta;
- ta+=a;
- }else if(ta>tc){
- sans+=d;
- if(tc-time>v){
- sans--;
- }
- time=tc;
- tc+=c;
- }
- }sans+=b+d-;
- cout<<tans*(t/tt)+sans<<endl;
- }
- }
- return ;
- }
K XOR Clique
题意:找一个最大的集合,使得这些任意两个异或后的值都比最小的那个小
思路:有个队友说可以用字典树,后来我想了想好像只需要计算每一个2,4,8,16,32,64,128,256,512,1024......这些区间的数字的个数就可以了,因为不同的这些2的次方它们异或之后显然最高位会是1,使得它们肯定会比最小的那个大,所以肯定是在同一个集合里面的,同一个集合里面的它们的第一位是相同的,所以异或之后肯定会比最小的那个数要小,所以统计区间个数就可以了,先打个表记录一下2的次方。
- #include<iostream>
- #include<cstdio>
- #include<algorithm>
- #include<cstring>
- #include<cmath>
- #include<cstdlib>
- #include<queue>
- #include<set>
- #include<stack>
- #include<vector>
- #include<map>
- #include<ctime>
- using namespace std;
- using namespace std;
- typedef long long ll;
- const int inf = 0x3f3f3f3f;
- const int maxn = 1e5 + ;
- int main()
- {
- ll a[];
- int sum[];
- for(ll i=;i<=;i++)
- {
- a[i]=(ll)pow(*1.0,i);
- // cout<<a[i]<<" ";
- }
- int t;
- while(~scanf("%d",&t))
- {
- while(t--)
- {
- int n;
- scanf("%d",&n);
- memset(sum,,sizeof sum);
- for(int i=;i<n;i++)
- {
- int x;
- scanf("%d",&x);
- for(int num=;num<=;num++)
- {
- if(x<a[num])
- {
- sum[num]++;
- break;
- }else
- continue;
- }
- }
- int maxx=-;
- for(int i=;i<=;i++)
- maxx=max(maxx,sum[i]);
- printf("%d\n",maxx);
- }
- }
- }
The 2018 ACM-ICPC Asia Qingdao Regional Contest(青岛网络赛)的更多相关文章
- The 2018 ACM-ICPC Asia Qingdao Regional Contest
The 2018 ACM-ICPC Asia Qingdao Regional Contest 青岛总体来说只会3题 C #include<bits/stdc++.h> using nam ...
- The 2018 ACM-ICPC Asia Qingdao Regional Contest(部分题解)
摘要: 本文是The 2018 ACM-ICPC Asia Qingdao Regional Contest(青岛现场赛)的部分解题报告,给出了出题率较高的几道题的题解,希望熟悉区域赛的题型,进而对其 ...
- ACM ICPC Central Europe Regional Contest 2013 Jagiellonian University Kraków
ACM ICPC Central Europe Regional Contest 2013 Jagiellonian University Kraków Problem A: Rubik’s Rect ...
- 2019-2020 ICPC, Asia Jakarta Regional Contest (Online Mirror, ICPC Rules, Teams Preferred)
2019-2020 ICPC, Asia Jakarta Regional Contest (Online Mirror, ICPC Rules, Teams Preferred) easy: ACE ...
- The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online J - Press the Button(思维)
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4056 题意 有一个按钮.一个灯.一个计时器和一个计数器,每按一次按钮,计时 ...
- The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online -C:Halting Problem(模拟)
C Halting Problem In computability theory, the halting problem is the problem of determining, from a ...
- The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online Solution
A Live Love 水. #include<bits/stdc++.h> using namespace std; typedef long long ll; ; const i ...
- 2018-2019, ICPC, Asia Yokohama Regional Contest 2018 K
传送门:https://codeforces.com/gym/102082/attachments 题解: 代码: /** * ┏┓ ┏┓ * ┏┛┗━━━━━━━┛┗━━━┓ * ┃ ┃ * ┃ ━ ...
- ZOJ - 4048 Red Black Tree (LCA+贪心) The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online
题意:一棵树上有m个红色结点,树的边有权值.q次查询,每次给出k个点,每次查询有且只有一次机会将n个点中任意一个点染红,令k个点中距离红色祖先距离最大的那个点的距离最小化.q次查询相互独立. 分析:数 ...
- 2018 ICPC Asia Jakarta Regional Contest
题目传送门 题号 A B C D E F G H I J K L 状态 Ο . . Ο . . Ø Ø Ø Ø . Ο Ο:当场 Ø:已补 . : 待补 A. Edit Distance Thin ...
随机推荐
- 使用URLRewriter实现URL重写
优点 1)隐藏真实URL,提高安全性 2)更加友好的URL,好记(看博客园就行知道啦) 3)便于搜素引擎收录 ......... 可能的缺点 使用URL重写可能导致: 1)图片路径的问题 2)CSS路 ...
- ElasticSearch入门-搜索(java api)
ElasticSearch入门-搜索(java api) package com.qlyd.searchhelper; import java.util.Map; import net.sf.json ...
- 018.Java类加载器
https://www.ibm.com/developerworks/cn/java/j-lo-classloader/ 类加载器(class loader) 用来加载 Java 类到 Java 虚拟 ...
- JQuery初识(三 )
一丶JQuery的文档操作 1.插入操作: 父元素.append(子元素) 解释:追加某元素,在父元素中添加新的子元素.子元素可以为:stirng|element(js对象)|JQuery元素 var ...
- css动画-模拟正余弦曲线
今天就写一个css3抛物线的动画吧= = 从左到右的抛物线动画,我们就暂且把动作分为匀速向右运动和变速的上下运动. 水平匀速运动我们可以利用 translateX(x):定义 2D 转换,沿着 X 轴 ...
- php 01
PHP 一.了解php 1.什么是php PHP 超文本预处理器 服务器端的脚本语言 是一种被广泛应用的开放源代码的多用途脚本语言 他可以嵌入到html中 尤其适用web开发 2.php在web中 ...
- WPF中的StackPanel、WrapPanel、DockPanel(转)
一.StackPanel StackPanel是以堆叠的方式显示其中的控件 1.可以使用Orientation属性更改堆叠的顺序 Orientation="Vertical" 默认 ...
- Redis集群维护、运营的相关命令与工具介绍
Redis集群的搭建.维护.运营的相关命令与工具介绍 一.概述 此教程主要介绍redis集群的搭建(Linux),集群命令的使用,redis-trib.rb工具的使用,此工具是ruby语言写的,用于集 ...
- ubuntu14.04server下安装scala+sbt工具
安装sbt参考https://www.cnblogs.com/wrencai/p/3867898.html 在安装scala时 首先得安装jdk环境,最好安装最新版本以免后续安装出现不必要的麻烦 一. ...
- 新增自定义聚合函数StrJoin
1.添加程序集Microsoft.SqlServer.Types CREATE ASSEMBLY [Microsoft.SqlServer.Types] AUTHORIZATION [sys] FRO ...