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的更多相关文章

  1. Google Kick Start 2019 C轮 第一题 Wiggle Walk 题解

    Google Kick Start 2019 C轮 第一题 Wiggle Walk 题解 题目地址:https://codingcompetitions.withgoogle.com/kickstar ...

  2. HYNB Round 15: PKU Campus 2019

    HYNB Round 15: PKU Campus 2019 C. Parade 题意 将平面上n*2个点安排在长度为n的两行上. 做法 首先可以忽略每个点之间的影响,只用考虑匹配即可 然后把所以点归 ...

  3. kick start 2019 round D T3题解

    ---恢复内容开始--- 题目大意:共有N个房子,每个房子都有各自的坐标X[i],占据每个房子需要一定花费C[i].现在需要选择K个房子作为仓库,1个房子作为商店(与题目不同,概念一样),由于仓库到房 ...

  4. kick start 2019 round D T2题解

    题目大意:由N个房子围成一个环,G个人分别顺时针/逆时针在房子上走,一共走M分钟,每分钟结束,每个人顺/逆时针走到相邻的房子.对于每个房子都会记录最后时刻到达的人(可能是一群人).最终输出每个人会被几 ...

  5. Kick Start 2019 Round A Contention

    $\DeclareMathOperator*{\argmax}{arg\,max}$ 题目链接 题目大意 一排 $N$ 个座位,从左到右编号 $1$ 到 $N$ . 有 $Q$ 个预定座位的请求,第 ...

  6. Kick Start 2019 Round H. Elevanagram

    设共有 $N = \sum_{i=1}^{9} A_i$ 个数字.先把 $N$ 个数字任意分成两组 $A$ 和 $B$,$A$ 中有 $N_A = \floor{N/2}$ 个数字,$B$ 中有 $N ...

  7. Kick Start 2019 Round A Parcels

    题目大意 $R \times C$ 的网格,格子间的距离取曼哈顿距离.有些格子是邮局.现在可以把至多一个不是邮局的格子变成邮局,问每个格子到最近的邮局的曼哈顿距离的最大值最小是多少. 数据范围 $ 1 ...

  8. Kick Start 2019 Round B Energy Stones

    对我很有启发的一道题. 这道题的解法中最有思维难度的 observation 是 For simplicity, we will assume that we never eat a stone wi ...

  9. 【DP 好题】Kick Start 2019 Round C Catch Some

    题目链接 题目大意 在一条数轴上住着 $N$ 条狗和一个动物研究者 Bundle.Bundle 的坐标是 0,狗的坐标都是正整数,可能有多条狗住在同一个位置.每条狗都有一个颜色.Bundle 需要观测 ...

随机推荐

  1. Vue中ajax返回的结果赋值

    这是第二次在项目中遇到此问题,ajax请求成功后在success函数中为Vue实例data里的变量赋值,却失败了 new Vue({ el:'#app', data:{ msg:'' }, creat ...

  2. day04 流程控制

    在python中流程控制主要有三种:顺序流程.分支流程.循环流程 1.顺序流程:在宏观上,python程序的运行就是自上而下的顺序流程: 2.分支流程:分支流程主要是  if...else....流程 ...

  3. shell的进度条【转】

    生成进度条的俩个shell脚本 !/bin/bash i= bar='' index= arr=( "|" "/" "-" "\\ ...

  4. Mock.js简易教程,脱离后端独立开发,实现增删改查功能(转)

    在我们的生产实际中,后端的接口往往是较晚才会出来,并且还要写接口文档,于是我们的前端的许多开发都要等到接口给我们才能进行,这样对于我们前端来说显得十分的被动,于是有没有可以制造假数据来模拟后端接口呢, ...

  5. 【easy】268. Missing Number

    Given an array containing n distinct numbers taken from 0, 1, 2, ..., n, find the one that is missin ...

  6. HDU-魔咒词典(字符串hash)

    魔咒词典 TimeLimit: 8000/5000 MS (Java/Others)  MemoryLimit: 32768/32768 K (Java/Others) 64-bit integer ...

  7. WPF 10天修炼 第八天 - 形状、画刷和变换

    图形 在WPF中使用绘图最简单的就是使用Shape类.Shape类继承自FrameworkElement,是一个专门用来绘图的类.Shape类中年派生的类有直线.矩形.多边形和圆形等. System. ...

  8. JVM内存模型分析(一个程序运行的例子)

    (.class字节码)类加载到内存之后,内存模型:(ps:.class文件可以通过javap 指令反编译成一个可读文件) 1.java栈,本地方法栈,程序计数器(每个线程私有) 看如下程序: 以该程序 ...

  9. java - day003 - 循环嵌套, 循环命名, while, 数组

    1.循环嵌套 break 中断循环或switch(跳出循环).中断后继续往下执行 continue (跳到循环的下一轮继续执行) return (结束方法) 2.循环命名 内层循环控制外层循环.需要给 ...

  10. Lesson 3-1(语句:条件语句)

    3.1 条件语句:if 语句 3.1.1 if 语句组成 --- if 语句包含:if 关键字.条件.冒号.if 子句(缩进代码块). --- if 语句表达的意思为:如果条件为真(True),执行后 ...