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(青岛网络赛)的更多相关文章

  1. The 2018 ACM-ICPC Asia Qingdao Regional Contest

    The 2018 ACM-ICPC Asia Qingdao Regional Contest 青岛总体来说只会3题 C #include<bits/stdc++.h> using nam ...

  2. The 2018 ACM-ICPC Asia Qingdao Regional Contest(部分题解)

    摘要: 本文是The 2018 ACM-ICPC Asia Qingdao Regional Contest(青岛现场赛)的部分解题报告,给出了出题率较高的几道题的题解,希望熟悉区域赛的题型,进而对其 ...

  3. 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 ...

  4. 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 ...

  5. The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online J - Press the Button(思维)

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4056 题意 有一个按钮.一个灯.一个计时器和一个计数器,每按一次按钮,计时 ...

  6. 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 ...

  7. 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 ...

  8. 2018-2019, ICPC, Asia Yokohama Regional Contest 2018 K

    传送门:https://codeforces.com/gym/102082/attachments 题解: 代码: /** * ┏┓ ┏┓ * ┏┛┗━━━━━━━┛┗━━━┓ * ┃ ┃ * ┃ ━ ...

  9. ZOJ - 4048 Red Black Tree (LCA+贪心) The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online

    题意:一棵树上有m个红色结点,树的边有权值.q次查询,每次给出k个点,每次查询有且只有一次机会将n个点中任意一个点染红,令k个点中距离红色祖先距离最大的那个点的距离最小化.q次查询相互独立. 分析:数 ...

  10. 2018 ICPC Asia Jakarta Regional Contest

    题目传送门 题号 A B C D E F G H I J K L 状态 Ο . . Ο . . Ø Ø Ø Ø . Ο Ο:当场 Ø:已补 .  :  待补 A. Edit Distance Thin ...

随机推荐

  1. PHP 中获取文件名及路径

    1. basename("/mnt/img/image01.jpg")函数:得到文件名;输出结果为:image01.jpg. 使用 basename($uriString) 我们可 ...

  2. linux下mysql-5.5.27.tar.gz源程序包安装实例

    研究了好几天,终于把mysql装上了,现在来做下小结. 系统环境:fedora8 虚拟机. 1.检查安装使用的编译工具gcc是否存在,如果不存在则要下载安装 # gcc -v 2.卸载低版本的mysq ...

  3. ThinkPHP- 3.1

    基础: 1. 基础概念 LAMP LAMP是基于Linux,Apache,MySQL和PHP的开放资源网络开发平台.这个术语来自欧洲,在那里这些程序常用来作为一种标准开发环境.名字来源于每个程序的第一 ...

  4. UVALive 4262——Trip Planning——————【Tarjan 求强连通分量个数】

    Road Networks Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Submit Stat ...

  5. 安卓adb调试命令常见的问题

    首先本人使用的是ubuntu系统,在Eclipse下开发的时候使用无线调试,在终端直接输入adb connect 114.114.114.114没有问题,给手机安装软件用adb install  ** ...

  6. Regexp:常用的几个正则表达式

    1.isEmail /** * * @desc 判断是否为邮箱地址 * @param {String} str * @return {Boolean} */ function isEmail(str) ...

  7. web安全防御之RASP技术

    作者:      我是小三 博客:      http://www.cnblogs.com/2014asm/ 由于时间和水平有限,本文会存在诸多不足,希望得到您的及时反馈与指正,多谢! 0x00:we ...

  8. 使用adbWireless无线调试Android真机设备[转]

    开发Android的朋友都知道,真机调试需要把手机与PC相连,然后把应用部署到真机上进行安装和调试.长长的USB线显得很麻烦,而且如果需要USB接口与其他设备连接的话显得很不方便.今天介绍一种不通过U ...

  9. 查看mysql历史命令

    默认情况下操作mysql会在家目录下创建一个隐藏的mysql历史命令文件.mysql_history 在管理授权mysql账户时也会记录这些明文密码到这个文件,非常的不安全 [root@localho ...

  10. 【强力卸载】使用Uninstall Tool卸载各类不易卸载的软件

    Uninstall Tool 经测试卸载MySql5.7.18成功. 下载地址: http://files.cnblogs.com/files/xiaohi/%E3%80%90%E8%BD%AF%E4 ...