抱着可能杭电的多校1比牛客的多校1更恐怖的想法 看到三道签到题 幸福的都快哭出来了好吗

1001  Maximum Multiple(hdoj 6298)

链接:http://acm.hdu.edu.cn/showproblem.php?pid=6298

签到题 但是有考了一定的思维 清北大佬两分钟写出来真的让人望尘莫及啊……

题意是给定一个n 可以由三个正整数相加得到 同时这三个正整数又是要被n可以整除 求这三个整数相乘的最大值 如果没有 则输出-1

既然题目没有要求三个正整数不能相等 则可以按照比例分成 3 3 3和2 2 4两堆

代码如下  一开始爆了int 在乘法前强制转换了long long

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std;
typedef long long ll;
int main(){
int t,n;
scanf("%d",&t);
while(t--){
scanf("%d",&n);
ll ans=;
if(n%==) ans=(ll)(n/)*(n/)*(n/);
else if(n%==) ans=(ll)(n/)*(n/)*(n/);
else ans=-;
printf("%lld\n",ans);
}
return ;
}

1003 Triangle Partition (hdoj 6300)

链接:http://acm.hdu.edu.cn/showproblem.php?pid=6300

签到题+1;

题意为要求有n个三角形 并且给3n个点 任意两个三角形不能相交 问应该如何组合这3n个点

因为在坐标中 任意三个点围起来都是三角形 而且题目中也有说明 给出的点任意三个点不在一条直线上 所以排序就好了

代码如下

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
struct node{
int x,y;
int id;
}kk[];
int cmp(node a,node b){
if(a.x==b.x) return a.y<b.y;
else return a.x<b.x;
}
int main(){
int t,n;
scanf("%d",&t);
while(t--){
scanf("%d",&n);
for(int i=;i<=*n;i++){
scanf("%d%d",&kk[i].x,&kk[i].y);
kk[i].id=i;
}
sort(kk+,kk+*n+,cmp);
for(int i=;i<=*n;i++){
printf("%d",kk[i].id);
if(i%==) printf("\n");
else printf(" ");
}
}
return ;
}

1004  Distinct Values (hdoj 6301)

链接:http://acm.hdu.edu.cn/showproblem.php?pid=6301

卡了三个半小时 还是没有做出来orz 一直t了九发 最后让一队帮忙查错 就是全局定义局部定义 清空方面的优化 我都已经想到了却没有上手写 这题没出来我背锅

题意为有一个长度为n的数列 其中有m个区间操作 在每个l到r中间 都严格满足数字不相等 并且满足字典序 最后输出这个数列

队友上手写的 大概讲一下做法 用的是小根堆+莫队思想  开一个空数组赋值 在操作区间外的位置 全部都赋值为1

想到一个优化的点 在对各个区间先按l从小到大再按r从小到大排序后 如果有一个区间是包含在别的区间中 可以直接continue 不需要再赋值

先记录所有边界的最大值为maxn 即可以放入的数字最大不超过maxn  把1到maxn都放入到一个队列中 对第一个区间进行查询 先赋值一遍 并把相应的数字从队列中弹出 再加入一个指针弹来弹去 把没有重叠可以使用的数字都重新放回到队列中 下一个区间可以使用的数字就从队列中按字典序取用

一个小的点 也是这回我的锅:memset的清空范围是数组定义的范围 如果数组非常大 哪怕输入数据很小 但还是会兢兢业业从头到尾清空一遍 遇到数据比较多的情况 可以手写一个for循环进行清空 可以节省不少时间

(队友)代码如下

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <algorithm>
#include <cstring>
#include <queue>
using namespace std;
int T,n,m,a[],topt,maxn;
struct data
{
int l,r;
}q[];
bool cmp(data aa,data bb){if (aa.l==bb.l) return aa.r<bb.r; return aa.l<bb.l;}
priority_queue<int,vector<int>,greater<int> >qq;
int main()
{ scanf("%d",&T);
while (T--)
{
topt=; maxn=;
while (!qq.empty()) qq.pop();
for(int i=;i<=n;i++) a[i]=;
scanf("%d%d",&n,&m);
for (int i=;i<=m;i++) scanf("%d%d",&q[i].l,&q[i].r),maxn=max(maxn,q[i].r);
for (int i=;i<=maxn;i++) qq.push(i);
sort(q+,q+m+,cmp);
for (int i=q[].l;i<=q[].r;i++) a[i]=qq.top(),qq.pop();;
int pl=q[].l,pr=q[].r;
for (int i=;i<=m;i++)
{
if (q[i].r<=pr) continue;
while (pl<q[i].l) {qq.push(a[pl]); pl++;}
while (pr<q[i].r) {pr++; a[pr]=qq.top(); qq.pop();}
}
for (int i=;i<=n;i++) if (a[i]==) a[i]=;
for (int i=;i<n;i++) printf("%d ",a[i]);
printf("%d\n",a[n]);
}
return ;
}

1011 Time Zone  (hdoj 6308)

链接:http://acm.hdu.edu.cn/showproblem.php?pid=6308

签到题+1;

题意为给出当前的北京时间 根据UTC来判断当前时区的时间  如果出现-X.Y的情况 Y=1就是6分钟

模拟题 感觉写起来还是有点麻烦的 稍不留意就写劈叉了  因为是时间类的题目 在边界上面还要有判断

PS:这个UTC是真的无比熟悉啊 打cf的时候天天见

代码如下

#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
using namespace std;
int main(){
int t;
scanf("%d",&t);
while(t--){
int a,b;
char s[];
scanf("%d%d UTC%s",&a,&b,s);
int len=strlen(s);
int tmp=;
if(s[]=='-'){
if(len==){
tmp=s[]-'';
a-=(tmp+);
if(a>=) a-=;
if(a<) a+=;
}
if(len==){
tmp=(s[]-'')*+(s[]-'');
a-=(tmp+);
if(a>=) a-=;
if(a<) a+=;
}
if(len==){
tmp=s[]-'';
a-=(tmp+);
b-=*(s[]-'');
if(b<) b+=,a--;
if(a>=) a-=;
if(a<) a+=;
}
if(len==){
tmp=(s[]-'')*+(s[]-'');
a-=(tmp+);
b-=*(s[]-'');
if(b<) b+=,a--;
if(a>=) a-=;
if(a<) a+=;
}
}
else if(s[]!='-'){
if(len==){
tmp=s[]-'';
a+=(tmp-);
if(a>=) a-=;
if(a<) a+=;
}
if(len==){
tmp=(s[]-'')*+(s[]-'');
a+=(tmp-);
if(a>=) a-=;
if(a<) a+=;
}
if(len==){
tmp=s[]-'';
a+=(tmp-);
b+=*(s[]-'');
if(b>=) b-=,a++;
if(a>=) a-=;
if(a<) a+=;
}
if(len==){
tmp=(s[]-'')*+(s[]-'');
a+=(tmp-);
b+=*(s[]-'');
if(b>=) b-=,a++;
if(a>=) a-=;
if(a<) a+=;
}
}
printf("%02d:%02d\n",a,b);
}
return ;
}

2018 Multi-University Training Contest 1 杭电多校第一场的更多相关文章

  1. 2018 Multi-University Training Contest 9 杭电多校第九场 (有坑待补)

    咕咕咕了太久  多校博客直接从第三场跳到了第九场orz 见谅见谅(会补的!) 明明最后看下来是dp场 但是硬生生被我们做成了组合数专场…… 听说jls把我们用组合数做的题都用dp来了遍 这里只放了用组 ...

  2. 2018 Multi-University Training Contest 2 杭电多校第二场

    开始逐渐习惯被多校虐orz  菜是原罪 1004  Game    (hdoj 6312) 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6312 虽然披着 ...

  3. 2018 Multi-University Training Contest 3 杭电多校第三场

    躺了几天 终于记得来填坑了 1001 Ascending Rating   (hdoj 6319) 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6319 ...

  4. 杭电多校第一场-M-Code

    题目描述 After returning with honour from ICPC(International Cat Programming Contest) World Finals, Tom ...

  5. 2019杭电多校第一场hdu6581 Vacation

    Vacation 题目传送门 update(O(n)) 看了那个O(n)的方法,感觉自己想的那个O(nlogn)的好傻,awsl. 0车最终通过停车线的时候,状态一定是某个车堵住后面的所有车(这个车也 ...

  6. 2019年杭电多校第一场 1009题String(HDU6586+模拟+单调栈)

    题目链接 传送门 题意 给你一个字符串,要你构造一个长为\(k\)的子串使得每个字母出现的次数在\([L_i,R_i](0\leq i\leq26)\)间且字典序最小. 思路 做这种题目就是要保持思路 ...

  7. 2019年杭电多校第一场 1004题Vacation(HDU6581+数学)

    题目链接 传送门 题意 有\(n+1\)辆车要过红绿灯,告诉你车的长度.与红绿灯的起点(题目假设红绿灯始终为绿).车的最大速度,问你第\(0\)辆车(距离最远)车头到达红绿灯起点的时间是多少(每辆车最 ...

  8. 2019年杭电多校第一场 1002题Operation(HDU6579+线性基)

    题目链接 传送门 题意 初始时有\(n\)个数,现在有\(q\)次操作: 查询\([l,r]\)内选择一些数使得异或和最大: 在末尾加入一个数. 题目强制在线. 思路 对于\(i\)我们记录\([1, ...

  9. [2019杭电多校第一场][hdu6582]Path(最短路&&最小割)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6582 题意:删掉边使得1到n的最短路改变,删掉边的代价为该边的边权.求最小代价. 比赛时一片浆糊,赛后 ...

随机推荐

  1. python自动化开发-[第六天]-常用模块、面向对象

    今日概要: 1.常用模块 - os模块 - random模块 - shutil模块 - hashlib模块 - pickle/json模块 - shelve模块 - configparser模块 - ...

  2. 如何在springcloud分布式系统中实现分布式锁?

    一.简介 一般来说,对数据进行加锁时,程序先通过acquire获取锁来对数据进行排他访问,然后对数据进行一些列的操作,最后需要释放锁.Redis 本身用 watch命令进行了加锁,这个锁是乐观锁.使用 ...

  3. Java中的Dom4j

    上一篇讲了Java中如何操作XML,现在介绍一个更厉害的方法,Dom4j ,百度查一下就知道,这个更强,更快,更简单. 自己下载jar包导入工具,下面来讲一个例子,我事先准备了一个XML文件,如下: ...

  4. 端口与进程-----Window cmd命令

    ********************  windows 篇 ********************** cmd命令: services.msc    打开本地服务页面 一.查看windows系统 ...

  5. NIO SocketChannel 【链接】

    Java NIO系列教程(一) Java NIO 概述 Java NIO系列教程(六) Selector Java NIO系列教程(二) Channel Java NIO系列教程(三) Buffer ...

  6. 解决Lost connection to MySQL server during query错误方法

    昨天使用Navicat for MySQL导入MySQL数据库的时候,出现了一个严重的错误,Lost connection to MySQL server during query,字面意思就是在查询 ...

  7. JAVA中局部变量 和 成员变量有哪些区别

    JAVA中局部变量 和 成员变量有哪些区别 1.定义的位置不一样<重点>***局部变量:在方法的内部成员变量:在方法的外部,直接写在类当中 2.作用范围不一样<重点>***局部 ...

  8. IO流--序列化流与反序列化流

    IO流--序列化流与反序列化流: 序列化流:把对象当做流一样写入到文本文件中 ObjectOutputSream(); 反序列化流:把文本文件中的流对象还原成对象ObjectInputSream(): ...

  9. 双数组Trie树中叶子结点check[t]=t的证明

    双数组Trie树,其实就是用两个一维数组来表示Trie树这种数据结构. 一个数组称为BASE,另一个数组为CHECK.转移条件如下: 对于状态s,接收字符c,转移到状态t BASE[s]+c=t CH ...

  10. [Android] [putty连接Android设备] [Android设备网络调试]

    file: system/core/adb/adb.c line: 921 /* for the device, start the usb transport if the ** android u ...