Round A - Kick Start 2019
a.链接:https://codingcompetitions.withgoogle.com/kickstart/round/0000000000050e01/00000000000698d6
题意:有n个学生,要从里面选出p个来。每一个学生都有一个能力值。
要求你选出来的一组学生能力是相同的,有的学生能力比较低,所以需要花费你的时间来提升学生能力,一个学生提升1个能力值需要1小时。
求最低花费。
方法:因为只能提高学生的能力值,不能降低,所以一定是选择能力值挨着的那些。将数组排序,然后计算前p个花费,再将窗口往后移动...分别计算。
#include <iostream>
#include <climits>
#include <algorithm>
#include <vector> using namespace std; static auto x = [](){
std::ios::sync_with_stdio(false);
std::cin.tie(NULL);
std::cout.tie(NULL);
}; int main(){
int t,n,p; cin>>t;
int tmp=;
int ii=;
while(ii<t){
cin>>n>>p;
vector<int> si;
for(int i=;i<n;i++){
cin>>tmp;
si.push_back(tmp);
}
if(p==){
cout<<"Case #"<<++ii<<": "<<<<endl;
continue;
}
sort(si.begin(),si.end());
int last=;
int minn=INT_MAX;
for(int i=;(i+p-)<n;i++){
if(i==){
for(int j=;j<p;j++){
last += si[p-]-si[j];
}
}else{
last-=si[i+p-]-si[i-];
last+=(si[i+p-]-si[i+p-])*(p-);
}
minn=min(minn,last);
}
cout<<"Case #"<<++ii<<": "<<minn<<endl;
}
return ;
}
b. https://codingcompetitions.withgoogle.com/kickstart/round/0000000000050e01/000000000006987d
没做出来啊,真是菜的不行....连题解都看不懂!!!
题意:r*c的方格,其中1表示邮局,0表示空地。每个空地都有个最短运输时间x(是所有的1到这个点的曼哈顿距离中最小的),总运输时间是每个空地最短运输时间最大的那个。让你添加一个邮局,求最小的总运输时间。(应该是这个意思吧。。。)
代码错误,只是暂时记录。
#include <iostream>
#include <climits>
#include <algorithm>
#include <vector> using namespace std; static auto x = [](){
std::ios::sync_with_stdio(false);
std::cin.tie(NULL);
std::cout.tie(NULL);
}; typedef struct locaa{
int x,y;
} loca; int main(){
int t,r,c; cin>>t;
int ii=;
char charr='';
while(ii<t){
vector<loca> yi,ling;
vector<int> lingdis;
cin>>r>>c;
for(int i=;i<r;i++){
for(int j=;j<c;j++){
cin>>charr;
if(charr==''){
ling.push_back({i,j});
lingdis.push_back(INT_MAX);
}else{
yi.push_back({i,j});
}
}
}
if(ling.size()==){
cout<<"Case #"<<++ii<<": "<<<<endl;
continue;
}
if(ling.size()==r*c){
int midx,midy;
if(r%==){
midx=(r+)/;
}else{
midx=r/;
}
if(c%==){
midy=(c+)/;
}else{
midy=c/;
}
int mhd=r-midx+c-midy;
cout<<"Case #"<<++ii<<": "<<mhd<<endl;
continue;
}
int maxx=INT_MIN;
int x,y;
for(int i=;i<ling.size();i++){
int minn=INT_MAX;
for(int j=;j<yi.size();j++){
int dis=abs(ling[i].x-yi[j].x)+abs(ling[i].y-yi[j].y);
minn=min(dis,minn);
}
lingdis[i]=minn;
if(minn>maxx){
maxx=minn;
x=ling[i].x;
y=ling[i].y;
}
}
yi.push_back({x,y});
int res=INT_MIN;
for(int i=;i<ling.size();i++){
lingdis[i]=min(lingdis[i],abs(ling[i].x-x)+abs(ling[i].y-y));
res=max(res,lingdis[i]);
} cout<<"Case #"<<++ii<<": "<<res<<endl;
}
return ;
}
/*
3
3 3
101
000
101
1 2
11
5 5
10001
00000
00000
00000
10001 */
Round A - Kick Start 2019的更多相关文章
- Google Kick Start 2019 C轮 第一题 Wiggle Walk 题解
Google Kick Start 2019 C轮 第一题 Wiggle Walk 题解 题目地址:https://codingcompetitions.withgoogle.com/kickstar ...
- HYNB Round 15: PKU Campus 2019
HYNB Round 15: PKU Campus 2019 C. Parade 题意 将平面上n*2个点安排在长度为n的两行上. 做法 首先可以忽略每个点之间的影响,只用考虑匹配即可 然后把所以点归 ...
- kick start 2019 round D T3题解
---恢复内容开始--- 题目大意:共有N个房子,每个房子都有各自的坐标X[i],占据每个房子需要一定花费C[i].现在需要选择K个房子作为仓库,1个房子作为商店(与题目不同,概念一样),由于仓库到房 ...
- kick start 2019 round D T2题解
题目大意:由N个房子围成一个环,G个人分别顺时针/逆时针在房子上走,一共走M分钟,每分钟结束,每个人顺/逆时针走到相邻的房子.对于每个房子都会记录最后时刻到达的人(可能是一群人).最终输出每个人会被几 ...
- Kick Start 2019 Round A Contention
$\DeclareMathOperator*{\argmax}{arg\,max}$ 题目链接 题目大意 一排 $N$ 个座位,从左到右编号 $1$ 到 $N$ . 有 $Q$ 个预定座位的请求,第 ...
- Kick Start 2019 Round H. Elevanagram
设共有 $N = \sum_{i=1}^{9} A_i$ 个数字.先把 $N$ 个数字任意分成两组 $A$ 和 $B$,$A$ 中有 $N_A = \floor{N/2}$ 个数字,$B$ 中有 $N ...
- Kick Start 2019 Round A Parcels
题目大意 $R \times C$ 的网格,格子间的距离取曼哈顿距离.有些格子是邮局.现在可以把至多一个不是邮局的格子变成邮局,问每个格子到最近的邮局的曼哈顿距离的最大值最小是多少. 数据范围 $ 1 ...
- Kick Start 2019 Round B Energy Stones
对我很有启发的一道题. 这道题的解法中最有思维难度的 observation 是 For simplicity, we will assume that we never eat a stone wi ...
- 【DP 好题】Kick Start 2019 Round C Catch Some
题目链接 题目大意 在一条数轴上住着 $N$ 条狗和一个动物研究者 Bundle.Bundle 的坐标是 0,狗的坐标都是正整数,可能有多条狗住在同一个位置.每条狗都有一个颜色.Bundle 需要观测 ...
随机推荐
- pythonのdjango 信号
一.内置信号 Django中提供了“信号调度”,用于在框架执行操作时解耦.通俗来讲,就是一些动作发生的时候,信号允许特定的发送者去提醒一些接受者. Model signals pre_init # d ...
- c# 序列化效率比拼
前言:作为开发人员,对象的序列化经常用到,特别是在现在前后端分离 采用json 交互 ,就将原来用过的几种方式总结了下,也算是做一个记录,顺便做了下性能测试. 1:内置 JavaScriptSeria ...
- 【R】资源整理
1.25本Python电子书 http://python.jobbole.com/29281/ Think Stats Dive Into Python A Byte Of Python Think ...
- Light OJ 1266 - Points in Rectangle
题目 Link 就是查询矩形内有多少个点. 分析 二维树状数组维护就好了,. Code #include <bits/stdc++.h> const int maxn = 1000 + 1 ...
- [Linux]信号集和sigprocmask信号屏蔽函数
一.概述 系统提供这样一种能力,就是创建一个信号集,然后传递给信号屏蔽函数,从而屏蔽向该进程发送的信号. 有一点需要注意的是,不能屏蔽SIGKILL和SIGSTOP信号. 信号集是sigset_t类型 ...
- ASP Action函数 如何接收client传递的数据(编辑中。。。)
参看链接:https://www.cnblogs.com/umlzhang/p/3654486.html 我这里总结一下,Action的参数的来源比较多 1.url 2.路由设定 3.post中的内容 ...
- 高可用Redis(九):Redis Sentinel
1.主从复制高可用的问题 主从复制高可用的作用 1.为master提供备份,当master宕机时,slave有完整的备份数据 2.对master实现分流,实现读写分离 但是主从架构有一个问题 1.如果 ...
- Day06(类包、内部类)
在static静态方法中能直接调用的方法只能是静态方法.要想调用其它非静态方法,需要借助对象. 类包:是Java提供的一种管理类文件的机制.可以解决类名冲突问题,在开发庞大应用程序时帮助开发人员管理庞 ...
- linux安装lamp环境(linux+apache+mysql+php)
源码安装 本次使用 Centos7.2 MySQL5.7.22 Apache2.4.37 PHP5.6.38 安装Apache 安装httpd和所需依赖:gcc, apr, apr-util,apr- ...
- pypi pack and upload
upload 403 error need to change the name in setup.py upload 400 error need to change the version of ...