TAT 第一场codeforces

B. Array Walk #暴力 #贪心

题目链接

题意

有\(a1, a2, ..., an\) 个格子(每个格子有各自分数),最初为1号格(初始分数为\(a1\)),支持两种走法(经过的格子分数会相应累加),只能走\(k\)步:①向右走。②向左走,但是每一次向左操作走完一格后不能再连续地向左移动,允许向左走的操作次数为\(z\)。现要求你走完k次后获得的最大分数。

分析

参考了官方题解,假定我们有\(t\)次移动是向左的,那么剩下\(k-t\)次向右,我们知道遍历的格子在\([1, 1+k-2t]\)的,即最终停留的位置一定为\(1+k-2t\)号格子(因为每一次的向左移动之后需要进行一次向右走)。

为保证解尽可能大,一定是选择分数最大 的 相邻格子 进行重复的折返。于是我们可以尝试着暴力枚举向左次数\(t\)(即暴力枚举最终停留位置)并一路向右遍历将分数累加(暂不包括折返所得),当然向右遍历的过程中,还要将当前路途中出现的 分数最大 的相邻格子 进行记录。直到将\(t\)枚举完,最优解即得。

#include <algorithm>
#include <cstdio>
using namespace std;
typedef long long ll;
const int MAXN = 1e5 + 5;
int a[MAXN];
int main(){
int Q; scanf("%d", &Q);
while(Q--){
int n, k, z; scanf("%d%d%d", &n, &k, &z);
for (int i = 1; i <= n; i++) scanf("%d", &a[i]);
int ans = 0;
//允许向左走,但每次向左走只能走一步,意味着要折返,考虑到分数越高越好,当然是要选择最大的相邻 分数对 进行重复的折返
for (int t = 0; t <= z; t++){ //“向左”操作t次 == 折返t次 (当t为0说明一路向右)
int pos = 1 + k - t * 2; //pos代表最终到达的位置,"1"代表 起始位置为1,折返t次就消耗t*2次操作
if(pos < 1) continue;
int mx = 0, sum = 0;
for (int i = 1; i <= pos; i++){ //计算分数
if(i < n - 1)
mx = max(mx, a[i] + a[i + 1]);//选择最大的相邻分数对
sum += a[i];//同时不断累加成绩(但注意,此时是累加前进时获得分数,没加上折返时获得分数)
}
ans = max(ans, sum + mx * t);
}
printf("%d\n", ans);
}
return 0;
}

C. Good String #暴力 #性质观察

题目链接

题意

给定由数字\(0-9\)组成的串\(s = t_1t_2...t_n\),现要求最少从\(s\)中删除几个字符,使得新串满足\(t_2...t_{n-1}t_{n}t_1 == t_{n}t_1t_2...t_{n-2}t{n-1}\)

分析

递推一下条件,可以得到\(t_1 = t_3 = ... = t_{2k-1}\) 以及\(t_2 = t_4 = ... = t_{2k}\),偶/奇数位置的字符各自相等,故满足\(good string\) 当且仅当 该串的字符种数不超过2种。(eg: \(23 23 23 23 ... 23\))

由于串仅有\(0-9\)种字符,于是我们枚举\([00, 99]\)数字组合,统计每一种组合在原串中 或连续 或间断 的出现次数,并找出最大次数\(A\),利用奇偶位置枚举数字组合的方式值得学习

然而这样交上去仍然会wa,参考了@farer_yyh的思路,你还需要额外地统计\(0-9\)在原串出现次数(即考虑删除后的新串只有一种字符),找出最大次数\(B\),最后取\(A\)和\(B\)的最大者,具体见代码

#include <algorithm>
#include <cstdio>
#include <cstring>
using namespace std;
typedef long long ll;
const int MAXN = 2e5 + 5;
char str[MAXN];
int num[11]; //digit:0-9
int main() {
int Q; scanf("%d", &Q);
while (Q--) {
memset(str, 0, sizeof(str));
memset(num, 0, sizeof(num));
scanf("%s", str);
int len = strlen(str);
if (len <= 2) {
printf("0\n");
continue;
}
for (int i = 0; i < len; i++)
num[str[i] - '0']++; //统计该字符串每种字符出现次数
int mymax = -1;
for (int hi = 0; hi <= 9; hi++) {
for (int lo = 0; lo <= 9; lo++) {
int cnt = 0;
for (int i = 0; i < len; i++) {
int c = str[i] - '0';
if (cnt & 1) {
if (c == hi)cnt++;
}
else {
if (c == lo)cnt++;
}
}
if (cnt & 1) cnt --; // (a,b)(a)的情况需要减1
//但是对于(a, a)(a)无法统计出
mymax = max(mymax, cnt); //统计出现次数最多的数字对(不一定连续)
}
}
for (int i = 0; i <= 9; i++) //保证不漏下奇数长度且只有一种字符的good string
mymax = max(mymax, num[i]);
printf("%d\n", len - mymax);
}
return 0;
}

Educational Codeforces Round 92 (Rated for Div. 2) B、C题解的更多相关文章

  1. Educational Codeforces Round 92 (Rated for Div. 2)

    A.LCM Problem 题意:最小公倍数LCM(x,y),处于[l,r]之间,并且x,y也处于[l,r]之间,给出l,r找出x,y; 思路:里面最小的最小公倍数就是基于l左端点的,而那个最小公倍数 ...

  2. Educational Codeforces Round 61 (Rated for Div. 2) D,F题解

    D. Stressful Training 题目链接:https://codeforces.com/contest/1132/problem/D 题意: 有n台电脑,每台电脑都有初始电量ai,也有一个 ...

  3. Educational Codeforces Round 81 (Rated for Div. 2) A-E简要题解

    链接:https://codeforces.com/contest/1295 A. Display The Number 贪心思路,尽可能放置更多位,如果n为奇数,消耗3去放置一个7,剩下的放1 AC ...

  4. Educational Codeforces Round 60 (Rated for Div. 2) - C. Magic Ship

    Problem   Educational Codeforces Round 60 (Rated for Div. 2) - C. Magic Ship Time Limit: 2000 mSec P ...

  5. Educational Codeforces Round 60 (Rated for Div. 2) - D. Magic Gems(动态规划+矩阵快速幂)

    Problem   Educational Codeforces Round 60 (Rated for Div. 2) - D. Magic Gems Time Limit: 3000 mSec P ...

  6. Educational Codeforces Round 43 (Rated for Div. 2)

    Educational Codeforces Round 43 (Rated for Div. 2) https://codeforces.com/contest/976 A #include< ...

  7. Educational Codeforces Round 35 (Rated for Div. 2)

    Educational Codeforces Round 35 (Rated for Div. 2) https://codeforces.com/contest/911 A 模拟 #include& ...

  8. Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings

    Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings 题目连接: http://cod ...

  9. Codeforces Educational Codeforces Round 44 (Rated for Div. 2) E. Pencils and Boxes

    Codeforces Educational Codeforces Round 44 (Rated for Div. 2) E. Pencils and Boxes 题目连接: http://code ...

随机推荐

  1. Cocos2d-x extensions库使用问题解决方法

    需要在加入头文件#include "cocos-ext.h" 1>e:\cocos\cocos2d-x\cocos2d-x-3.10\extensions\gui\cccon ...

  2. 获取url中查询字符串参数

    // 获取url中查询字符串参数 例如http://www.test.com?a=1&b=2 function RequestParamete() { var url = window.loc ...

  3. lora传输模块的特点概述

    现今Lora已经是一种在物联网中广泛应用的技术,它是一种无线调制的方式,相对于传统的FSK调制技术来说,Lora在抑制同频干扰方面有非常大的优势,它解决了无法同时兼顾距离.抗扰和功耗不足的问题;另外l ...

  4. 20200726_java爬虫_使用HttpClient模拟浏览器发送请求

    浏览器获取数据: 打开浏览器 ==> 输入网址 ==> 回车查询 ==> 返回结果 ==> 浏览器显示结果数据 HttpClient获取数据: 创建HttpClient ==& ...

  5. 在IIS中部署前后端应用,多么痛的领悟!

    目前手上的Web项目是前后端分离的,所以有时也会倒腾Vue框架. 前后端应用最终以容器形态.在k8s中部署, 为此我搭建了基于Gitlab flow的Devops流程. 在Devops实践中,容器部署 ...

  6. 你说一下对Java中的volatile的理解吧

    前言 volatile相关的知识其实自己一直都是有掌握的,能大概讲出一些知识,例如:它可以保证可见性:禁止指令重排.这两个特性张口就来,但要再往深了问,具体是如何实现这两个特性的,以及在什么场景下使用 ...

  7. mysql运维-slave_skip_errors

    1 简介    mysql在主从复制过程中,由于各种的原因,从服务器可能会遇到执行BINLOG中的SQL出错的情况,在默认情况下,服务器会停止复制进程,不再进行同步,等到用户自行来处理.    sla ...

  8. C#3新增语法特性

    C#3,.Net Framework 3.5 ,Visual Studio 2008, CLR 3.0 C#3.0新引进的语法基于.Net Framework 3.5.主要引进的语法:Linq,隐式类 ...

  9. 云计算之路-出海记-小目标:Hello World from .NET 5.0 on AWS

    品尝过船上的免费晚餐,眺望着 aws 上搭建博客园海外站的宏伟目标,琢磨着眼前可以实现的小目标,不由自主地在屏幕上敲出了 -- "Hello World!",就从这个最简单朴实的小 ...

  10. AQS源码深入分析之条件队列-你知道Java中的阻塞队列是如何实现的吗?

    本文基于JDK-8u261源码分析 1 简介 因为CLH队列中的线程,什么线程获取到锁,什么线程进入队列排队,什么线程释放锁,这些都是不受我们控制的.所以条件队列的出现为我们提供了主动式地.只有满足指 ...