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 需要观测 ...
随机推荐
- Burp插件开发——环境配置
最近打算开发个Burp插件,从网上各种地找资料学习.第一步就应该是环境配置,请见下文. (其实最重要的前提是你已经安装了Burp,否则下面的所有内容都是无稽之谈了. https://pan.baidu ...
- Ubuntu的sources.list
参考文章: https://blog.csdn.net/u012843189/article/details/80964287 位于/etc/apt/sources.list 其中 deb http: ...
- Android运行时权限
Android 6.0加入了运行时权限这一概念.对于危险权限,应用必须在使用的时候进行申请.可以使用命令行查看危险权限:adb shell pm list permissions -d -g CALE ...
- loj题目总览
--DavidJing提供技术支持 现将今年7月份之前必须刷完的题目列举 完成度[23/34] [178/250] 第 1 章 贪心算法 √ [11/11] #10000 「一本通 1.1 例 1」活 ...
- VUE 父组件与子组件交互
1. 概述 1.1 说明 在项目过程中,会有很多重复功能在多个页面中处理,此时则需要把这些重复的功能进行单独拎出,编写公用组件(控件)进行引用.在VUE中,组件是可复用的VUE实例,此时组件中的dat ...
- tensorflow调试tfdbg
tensorflow调试工具:tfdbg 使用教程:https://www.cnblogs.com/hellcat/articles/7812119.html 遇到的错误信息及解决方案 ModuleN ...
- 先进过程控制之一:浅说APC
先进过程控制(APC)技术作为在生产装置级的信息化应用,在优化装置的控制水平和提高生产过程的管理水平的同时,还为企业创造了可观的经济效益. 1.什么是APC 先进过程控制,简称APC,并不是什么新概念 ...
- Jenkins+maven环境部署
选择使用tomcat下运行jenkins项目,安装步骤如下 1. 安装tomcat,查看想要下载的版本 https://mirrors.cnnic.cn/apache/tomcat/ wget h ...
- sql server 实现split功能 行转列
--實現split功能的函數create function [dbo].[func_split]( @SourceSql varchar(max), @StrSeprate varchar(10))r ...
- linux - word frequency
linux 输出某个文件的单词出现频率 解决方式 cat words.txt |awk '{for(i=1;i<=NF;i++) print $i;}'|sort|uniq -c|sort - ...