抱着可能杭电的多校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. 如何再window下统计自己写的代码行

    git log --since="2018-05-01" --before="2018-11-5" --author="$(git config -- ...

  2. Hbase学习02

    第2章 Apache HBase配置 本章在“入门”一章中进行了扩展,以进一步解释Apache HBase的配置. 请仔细阅读本章,特别是基本先决条件,确保您的HBase测试和部署顺利进行,并防止数据 ...

  3. SQL Server没有足够的内存继续执行程序

    有一个表的数据特别大,我点击生成脚本的时候,喜欢新建窗口,但是不行,数据量太大了,所以选择保存文件,保存到本地了.然后我点击执行,又报没有内存去执行...还是因为数据量太大了 解决办法,使用sqlcm ...

  4. mavan安装本地jar

    mvn install:install-file -Dfile=E:\IDEAworkspace\importAnalysisDemo\lib\IKAnalyzer2012_u6.jar -Dgrou ...

  5. IDEA DEBUG无法启动

    如题:idea DEBUG无法启动 解决方法: 1.查找出占用进程id 2.杀死进程 cmd 输入 命令: 1.netstat -ano|findstr 4405 2.taskkill -f -pid ...

  6. HTML第四耍 超链接标签

    1.HTML 超链接(链接) 一.HTML 超链接 HTML中使用超级链接与网络上的另一个文档相连.几乎可以在所有的网页中找到链接.点击链接可以从一张页面跳转到另一张页面. 超链接可以是一个字,一个词 ...

  7. java基础之反射---重要

    java反射: 反射是框架设计的灵魂 (使用的前提条件:必须先得到代表的字节码的Class,Class类用于表示.class文件(字节码)):   1:获取Class字节码文件对象的三种方式: /** ...

  8. Http状态码解释

    参考:urllib与urllib2的学习总结(python2.7.X) # Table mapping response codes to messages; entries have the # f ...

  9. Silverlight用户无法注册之MySql.Data.dll不一致

    本篇博文记录本人解决一个"用户无法注册"的问题的过程 1 问题描述: 用户可以删除:但不能注册,也不能修改权限: 图 1用户注册失败 图 2修改用户权限出错 2 解决过程 1)粗暴 ...

  10. Webpack2学习记录-1

    1.安装前准备 安装 webpack 之前,需要安装 node,这时最新的是 6,npm 是 4.如果有老的 node 项目在跑建议安装下 nvm. 2.建议安装在局部,即在项目下的 node_mod ...