比赛传送门

再次改下写博客的格式,以锻炼自己码字能力


A. Suits

题意:有四种材料,第一套西装需要 \(a\)、\(d\) 各一件,卖 \(e\) 块;第二套西装需要 \(b\)、\(c\)、\(d\) 各一件,卖 \(f\) 块。问,怎么做套装卖的前最多。

题解:【贪心】---- 先选比较贵的那一套,因为 \(d\) 套都要用上则以它为基准,再用剩余材料加第二套的总价钱

// https://codeforces.com/contest/1271/problem/A
#include<iostream>
#include<cstdio>
using namespace std; int a, b, c, d, e, f; int main()
{
int ans = 0;
cin >> a >> b >> c >> d >> e >> f;
int mmoney = max(e, f); // 比较二者谁更贵
if(mmoney == f){
int l = min(d, min(b, c));
ans += l * f;
d -= l;
int r = min(a, d);
ans += r * e;
}
else {
int r = min(a, d);
ans += r * e;
d -= r;
int l = min(d, min(b, c));
ans += l * f;
}
printf("%d\n", ans);
return 0;
}


B. Blocks

题意:翻转地砖使其最后的砖块颜色都一样,每翻转一块都要带动它相邻的右边一块(自左向右),输出最少翻转数以及每次翻转的位置

题解:【搜索】【翻转】数据很小,可以分别讨论每次翻成白或者翻成黑两种情况,以得到最后较小的情况(注意有翻不到的情况)

// https://codeforces.com/contest/1271/problem/B
#include<iostream>
#include<cstdio>
using namespace std; int n;
char ch[202];
int num[202]; // 分别存储黑白两种答案
int black[1002];
int white[1002]; int main()
{
scanf("%d", &n);
scanf("%s", ch);
for(int i = 0; i < n; i++){
if(ch[i] == 'B') num[i] = 1;
else num[i] = 0;
}
// 先判断全黑的
int b = 0, w = 0;
bool can = false; // 判断能否满足要求
for(int i = 0; i < n - 1; i++){
if(num[i] != 1) { // 如果该块不是黑色则翻 将会带动下一块的颜色变化
num[i] = 1 - num[i];
num[i + 1] = 1 - num[i + 1];
black[b++] = i + 1;
}
}
if(num[n - 1] == 1) can = true;
else b = 0x3f3f3f3f; // 重新初始化 num[] 判断全白的
for(int i = 0; i < n; i++){
if(ch[i] == 'B') num[i] = 1;
else num[i] = 0;
}
for(int i = 0; i < n - 1; i++){
if(num[i] != 0){
num[i] = 1 - num[i];
num[i + 1] = 1 - num[i + 1];
white[w++] = i + 1;
}
}
if(num[n - 1] == 0) can = true;
else w = 0x3f3f3f3f; if(!can) printf("-1\n");
else if(w > b){
printf("%d\n", b);
for(int i = 0; i < b; i++){
printf("%d%c", black[i], i == b - 1 ? '\n' : ' ');
}
}
else {
printf("%d\n", w);
for(int i = 0; i < w; i++){
printf("%d%c", white[i], i == w - 1 ? '\n' : ' ');
}
}
return 0;
}


C. Shawarma Tent

题意:有一群学生从学校回家,他们都会走曼哈顿距离的最近距离,然后让你建一个商店在他们的路上,使他们经过商店的人数最多

题解:【贪心】涉及到曼哈顿距离,所以学生们只能按坐标轴上的线走而不能走斜线,同时商店的位置除了学校可以任意取,就可以定位在学校的上下左右四个方向取其中的一个点即可。对应四个方向,可以把学生的点分为四个象限,然后求这四个象限里哪个象限的点最多即可。

// https://codeforces.com/contest/1271/problem/C
#include<iostream>
#include<cstdio>
using namespace std; int n, W, H, w, h;
int dw[] = { 0, 1, 0, -1 }, dh[] = { 1, 0, -1, 0 };
int d[4]; int main()
{
scanf("%d %d %d", &n, &W, &H);
while(n--){
scanf("%d %d", &w, &h);
if(w != W) d[w > W ? 1 : 3]++;
if(h != H) d[h > H ? 0 : 2]++;
} int m = 0, t;
for(int i = 0; i < 4; i++){
// printf("i:%d d:%d\n", i, d[i]);
if(d[i] > m){
m = d[i]; t = i;
}
} printf("%d\n", m);
printf("%d %d\n", W + dw[t], H + dh[t]);
return 0;
}


补题没有rating。

【cf补题记录】Codeforces Round #608 (Div. 2)的更多相关文章

  1. Codeforces Round #608 (Div. 2) 题解

    目录 Codeforces Round #608 (Div. 2) 题解 前言 A. Suits 题意 做法 程序 B. Blocks 题意 做法 程序 C. Shawarma Tent 题意 做法 ...

  2. 【cf补题记录】Codeforces Round #607 (Div. 2)

    比赛传送门 这里推荐一位dalao的博客-- https://www.cnblogs.com/KisekiPurin2019/ A:字符串 B:贪心 A // https://codeforces.c ...

  3. CF每日一练 Codeforces Round #520 (Div. 2)

    比赛过程总结:过程中有事就玩手机了,后面打的状态不是很好,A题理解错题意,表明了内心不在状态,B题想法和思路都是完全正确的,但是并没有写出来,因为自己代码能力不强,思路不是特别清晰,把代码后面写乱了, ...

  4. Codeforces Round #608 (Div. 2) D. Portals

    链接: https://codeforces.com/contest/1271/problem/D 题意: You play a strategic video game (yeah, we ran ...

  5. [CF百场计划]Codeforces Round #617 (Div. 3)

    A. Array with Odd Sum Description You are given an array \(a\) consisting of \(n\) integers. In one ...

  6. 【做题】Codeforces Round #453 (Div. 1) D. Weighting a Tree——拆环

    前言:结论题似乎是我的硬伤…… 题意是给你一个无向图,已知连接到每一个点的边的权值和(为整数,且属于区间[-n,n]),需要求出每条边权值的一个合法解(都要是在区间[-2*n^2,2*n^2]内的整数 ...

  7. 【做题】Codeforces Round #436 (Div. 2) F. Cities Excursions——图论+dfs

    题意:给你一个有向图,多次询问从一个点到另一个点字典序最小的路径上第k个点. 考虑枚举每一个点作为汇点(记为i),计算出其他所有点到i的字典序最小的路径.(当然,枚举源点也是可行的) 首先,我们建一张 ...

  8. 【做题】Codeforces Round #429 (Div. 2) E. On the Bench——组合问题+dp

    题目大意是给你n个数,求相邻两数相乘不是完全平方数的排列数. 一开始看到这题的时候,本人便想给相乘为完全平方数的数对建边,然后就写萎了... 后来通过集体智慧发现这个重要性质:对于自然数a,b,c,若 ...

  9. Codeforces Round #608 (Div. 2)

    传送门 A. Suits 签到. Code /* * Author: heyuhhh * Created Time: 2019/12/15 17:16:33 */ #include <iostr ...

随机推荐

  1. 全链路追踪技术选型:pinpoint vs skywalking

    目前分布式链路追踪系统基本都是根据谷歌的<Dapper大规模分布式系统的跟踪系统>这篇论文发展而来,主流的有zipkin,pinpoint,skywalking,cat,jaeger等. ...

  2. VSCode打字特效Power Mode插件

    由于最近比较频繁使用VSCode这个软件写代码,然后里面有一个非常炫酷的打字特效插件,平时写代码的时候不会感觉太枯燥(其实就是装一下逼吧)! 安装很简单,但是容易忘,所以这里整理一下具体的部署步骤. ...

  3. lua中,两种json和table互转方法的效率比较

    lua中json和table的互转,是我们在平时开发过程中经常用到的.比如: 在用lua编写的服务器中,如果客户端发送json格式的数据,那么在lua处理业务逻辑的时候,必然需要转换成lua自己的数据 ...

  4. 解决SpringBoot无法读取js/css静态资源的新方法

    前言 作为依赖使用的SpringBoot工程很容易出现自身静态资源被主工程忽略的情况.但是作为依赖而存在的Controller方法却不会失效,我们知道,Spring MVC对于静态资源的处理也不外乎是 ...

  5. golang 学习笔记 ---new()和 make()的区别详解

    概述 Go 语言中的 new 和 make 一直是新手比较容易混淆的东西,咋一看很相似.不过解释两者之间的不同也非常容易. new 的主要特性 首先 new 是内建函数,你可以从 http://gol ...

  6. Nginx-Tomcat 等运维常用服务的日志分割-logrotate

    目录 一 .Nginx-Tomcat 等常用服务日志分析 Nginx 日志 Tomcat日志 MongoDB 日志 Redis 日志 二 .日志切割服务 logrotate 三.日志切割示例 Ngin ...

  7. sql比较字符串,比的到底是什么?

    sql里有nvarchar类型的日期数据time1:2019-10-09 00:00:00, 现给定string类型日期time2:2019-10-01 23:59:59,比较两个日期的大小, 发现可 ...

  8. ASP.NET Core 3.0 WebApi 系列【1】创建ASP.NET Core WebApi 项目

    目录 写在前面 一.运行环境 二.项目搭建 三.测试 API 四.基础知识 五.写在最后 写在前面 C#语言可以创建RESTful服务,被称作WebApi.在这里总结学习使用支持创建.读取.更新.删除 ...

  9. 2019 大众书网Java面试笔试题 (含面试题解析)

      本人5年开发经验.18年年底开始跑路找工作,在互联网寒冬下成功拿到阿里巴巴.今日头条.大众书网等公司offer,岗位是Java后端开发,因为发展原因最终选择去了大众书网,入职一年时间了,也成为了面 ...

  10. datagrid相关

    int rowID = Convert.ToInt32(dataGrid_OpenBoxScan.CurrentRowIndex.ToString());//得到所选行的行号              ...