AcWing 第82场周赛

news2024/12/28 18:51:37

AcWing 第82场周赛

竞赛 - AcWing

B 4783. 多米诺骨牌 - AcWing题库

模拟题,考察代码描述问题的能力。

由题意所给的数学形式化定义中看出,所给的骨牌初始序列 LR 的顺序一定是相互交错的,即 ...LRLRLRLR...

所以,一旦遇到 L ,那么下一个一定是 R ;一旦遇到 R ,那么下一个一定是 L

Snipaste_2022-12-18_01-31-35.png

所以我们要处理的是2种区间:

  • L ... R
  • R ... L

对于初始序列的两端,由于可能是 . 开头,所以对初始序列的两端做初始处理,然后得到中间的两端为 LR 的序列。

  • 对于 L ... R => <- ... -> :显然中间区间的所有牌都不会倒
  • 对于 R ... L => -> ... <- :显然只有最中间的牌不会倒
    • 如果区间牌数为奇数,则只剩下1张牌不会倒
    • 如果区间牌数位偶数,则所有牌都会倒
#include <bits/stdc++.h>
using namespace std;
int n, ans;
string str;
int main() {
    cin >> n >> str;
    int l = 0;
    while (l < n && str[l] == '.')
        l++;
    if (l == n) {
        cout << n;
        return 0;
    }
    if (str[l] == 'R')
        ans += l - 0;
    int r = n - 1;
    while (0 <= r && str[r] == '.')
        r--;
    if (r == -1) {
        cout << n;
        return 0;
    }
    if (str[r] == 'L')
        ans += n - 1 - r;
    
    int cnt = 0;
    for (int i = l + 1; i <= r; i++) {
        // 在遇到L或R之前,统计"."的个数
        if (str[i] == '.') cnt++;
        else {
            // R ... L => -> ... <-
            if (str[i] == 'L') {
                ans += cnt & 1 ? 1 : 0;
                cnt = 0;
            }
            // L ... R => <- ... ->
            else {
                ans += cnt;
                cnt = 0;
            }
        }
    }
    cout << ans;
    return 0;
}

C AcWing 4784. 构造序列 - AcWing

模拟题,考察构造能力。

数学思路就是高中数学排列组合的「隔板法」。

n n n0 一共产生 n + 1 n+1 n+1 个空位,因为 0 之间必须间隔 1

  • 最少 1 的情况:01序列两端都是 0 ,则有中间要填充 n − 1 n-1 n1 个空位,此时序列为:0101..1010 ,于是有 m ≥ n − 1 m \ge n-1 mn1
  • 最多 1 的情况:01序列的 n + 1 n+1 n+1 个空位全部由 11 填充,此时序列为:11011...11011 ,于是有 m ≤ 2 × ( n + 1 ) m \le 2 \times (n+1) m2×(n+1)

于是可以先对不满足上述两条的数据进行特判,然后对合法输入进行分析:

策略是:

  • m > n − 1 m > n-1 m>n1 时,由于 1 的数量完全够,所以可以先尽可能用掉,防止现在保守导致后面放不完。先摆放 11 ,放了1个 11 自然要放1个 0 隔开,放了1个 0 自然再开始放 1 ,如此进行
  • 等到 m ≤ n − 1 m \le n-1 mn1 时,1 的数量刚刚好了,现在每次只能放 1 了。先摆放 1 ,再摆放 0 ,如此进行

最后如果剩余 0 0 0 个或 1 1 1 个或 2 2 21 ,直接摆放在末尾即可。

#include <bits/stdc++.h>
using namespace std;
int n, m;

int main() {
    scanf("%d%d", &n, &m);
    if (m < n - 1 || m > ((n + 1) << 1)) {
        printf("-1");
        return 0;
    }

    while (n) {
        // 先摆放11或1,取决于m够不够
        // 1. m>n-1时,for循环摆放11,printf摆放0
        // 2. m<=n-1时,由于m和n只相差1,所以m--和n--会使得重新满足m>n-1,于是for循环摆放1,printf摆放0
        for (int i = 1; i <= 2; i++)
            if (m > n - 1) {
                printf("1");
                m--;
            } else
                break;
        // 再摆放0隔开
        printf("0");
        n--;
    }
    // 最后把剩余的1摆放完(此时m=0或1或2)
    while (m--)
        printf("1");
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/99482.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

KNN算法 搜索最优超参数:n_neighbors/weights/p

目录 一&#xff1a;遍历参数 超参调优测试 二&#xff1a;网格模型 超参调优测试 三&#xff1a;模型保存 四&#xff1a;模型使用 一&#xff1a;遍历参数 超参调优测试 1.1 超参调试&#xff0c;找到模型最优解[仅做测试&#xff0c;得出最优&#xff1a;n_neighbors, …

PowerDesigner导入SQL脚本生成带中文注释(comment)的ER图并保存为图片格式(含通用可执行vb脚本文件)

目录 1、安装数据库建模工具PowerDesigner 16.5 2、打开 PowerDesigner&#xff0c;选择反向工程 3、选择数据库类型 4、导入SQL脚本文件并生成数据库表模型 5、去掉Diagram画板黑色网格线&#xff08;选做&#xff09; 6、ER图常规显示&#xff08;包含是否为Null及表名…

D. Same Count One(模拟 + 思维转换(行不行,从列入手))

Problem - D - Codeforces ChthollyNotaSeniorious收到了AquaMoon的一份特殊礼物&#xff1a;n个长度为m的二进制数组。AquaMoon告诉他&#xff0c;在一次操作中&#xff0c;他可以选择任何两个数组和1到m中的任何位置&#xff0c;并交换这些数组中位置的元素。 他对这个游戏很…

RabbitMQ知识总结一

更多知识在我的语雀平台&#xff1a; https://www.yuque.com/ambition-bcpii/muziteng RabbitMQ 1. RabbitMQ引言 1.1 什么是MQ MQ&#xff08;Message Queue&#xff09;消息队列&#xff0c;是基础数据结构中“先进先出”的一种数据结构。一般用来解决应用解耦&#xff0…

带token的登陆页面爆破方法(burp宏+爬虫脚本分享)

文章目录前言一、token参数分析二、burp设置宏操作三、爬虫脚本四、小结前言 在工作中&#xff0c;会遇到很多登陆页面有token保护&#xff0c;如果用Burpsuite直接抓取数据包并使用爆破模块&#xff0c;则会因token过期导致无法爆破。此时至少可以采用三种办法&#xff1a; 第…

Java诊断工具——arthas,实时监控,了解一下

文章目录1、arthas 简介官方文档2、arthas 的使用场景3、安装&启动3.1 安装3.2 启动4、常用命令5、使用示例5.1 stack5.2 jad5.3 sc5.4 watch5.5 trace5.6 jobs5.7 logger5.8 dashboard5.9 redefine6、其它1、arthas 简介 arthas是由阿里巴巴中间件团队开源的Java诊断工具。…

kubernetes对外服务之Ingress

目录 ​​​​​​​一、Ingress 是什么 1.1Service的作用 1.2Ingress简介 二、Ingress 安装 三、Ingress 代理访问 3.1Ingress HTTP 代理访问 3.2 Ingress: HTTPS 代理访问 3.3Ingress Contronler怎么工作的&#xff1f; ​​​​​​​​​​​​​​一、Ingress 是什…

Java核心实操:内存溢出 实战、内存泄漏实战

文章很长&#xff0c;而且持续更新&#xff0c;建议收藏起来&#xff0c;慢慢读&#xff01;疯狂创客圈总目录 博客园版 为您奉上珍贵的学习资源 &#xff1a; 免费赠送 :《尼恩Java面试宝典》 持续更新 史上最全 面试必备 2000页 面试必备 大厂必备 涨薪必备 免费赠送 经典…

ARM系列之MMU TLB和ASID基础概念介绍。

目录1、为什么要设计TLB&#xff1f;TLB中不包含我们需要的映射关系怎么办&#xff1f;2、TLB中都包含了啥&#xff1f;3、那什么是ASIDAddress Space ID&#xff08;ASID&#xff09;4、小结内存寻址简要过程如下&#xff1a;VA以页表大小取余&#xff0c;得到PA的低位&#x…

Go sync.Pool池化的学习

一句话总结&#xff1a;保存和复用临时对象&#xff0c;减少内存分配&#xff0c;降低 GC 压力。 一.前言 Go 语言标准库也大量使用了 sync.Pool&#xff0c;例如 fmt 和 encoding/json。 1.1 要解决的问题 一个新技术亦或是一个新名词&#xff0c;总是为了解决一些问题才出…

数据挖掘课程设计报告总结

一、实验题目 实验一 Apriori算法设计与应用 二、背景介绍 Apriori算法是一种挖掘关联规则的频繁项集算法&#xff0c;其核心思想是通过候选集生成和向下封闭检测两个阶段来挖掘频繁项集。 三、实验内容 1.3.1 运用的理论知识 关联规则挖掘是数据挖掘中最活跃的研究方法之…

数控恒流源电路简单讲解

&#xff08;1&#xff09;最近课设是做一个可步进的恒流源&#xff0c;所以查查找了很多资料之后。说一下自己对于恒流源电路的简单理解。 &#xff08;2&#xff09;我只是会将怎么使用和调整数据进行讲解&#xff0c;至于为什么这样只会讲我懂的部分。本人知道的也不是很多&…

【RPA前置知识】 整理并总结ForEach Activity类

&#x1f40b;作者简介&#xff1a;博主是一位.Net开发者&#xff0c;同时也是RPA和低代码平台的践行者。 &#x1f42c;个人主页&#xff1a;会敲键盘的肘子 &#x1f430;系列专栏&#xff1a;.Net实用方法总结 &#x1f980;专栏简介&#xff1a;本专栏介绍如何编写 Windows…

Biopython教程

Biopython教程 参考&#xff1a; https://biopython-cn.readthedocs.io/zh_CN/latest/index.html 蛋白质文件获取 Entrez方法 from Bio import Entrez Entrez.email邮箱名 #如123456789qq.com handleEntrez.esearch(dbprotein,term2rbg) recordEntrez.read(handle) idrecor…

C++PrimerPlus 第八章 函数探幽-8.2 引用变量

目录 8.2 引用变量 8.2.1 创建引用变量 8.2.2 将引用用作函数参数 8.2.3 引用的属性和特别之处 8.2.3.1 临时变量、引用参数和const 8.2.4 将引用用于结构 8.2.4.1 程序说明 8.2.4.2 为何要返回引用 8.2.4.3 返回引用时需要注意的问题 8.2.4.4 为何将const用于引用返…

纳米柱阵列超颖表面构建模块的严格分析

摘要 利用先进的制造技术&#xff0c;人们成功实现了具有高数值孔径的可见波长的超透镜。通常使用空间变化的纳米结构作为模块来构建超透镜。在这个例子中分析了用于组成偏振不敏感超透镜的纳米柱状结构。利用傅立叶模态方法&#xff08;FMM&#xff0c;也称为RCWA&#xff09;…

Windows配置开机自启jar包,不显示黑窗口,并输出日志

背景 如果是在 Linux 下开机自启一个服务相对比较简单&#xff0c;这次遇到一个需求是关于 Windows 开机自启的&#xff1a; 在 Windows 环境下开机自动运行一个 SpringBoot 服务&#xff1b;而且由于是一个后台服务&#xff0c;要求对终端用户无感知&#xff1b;为后期维护方…

AC自动机的实现思想与原理

1. 基本介绍 本文最先发布于博客园&#xff0c;原地址&#xff1a;AC自动机的实现与思想原理 - yelanyanyu - 博客园 (cnblogs.com) 1.1案例引入 有一个字典有若干的敏感词 String[] str;&#xff0c;有一个大文章 string&#xff0c;我们要找到大文章中出现的所有的敏感词&…

物联网ARM开发- 6协议 FSMC模拟8080时序驱动LCD(上)

目录 一、常见显示器介绍 1、显示器分类 2、显示器的基本参数 二、TFT-LCD控制原理 1、TFT-LCD结构 2、TFT-LCD控制框图 3、控制原理 LCD数据传输时序 LCD数据传输时序参数 三、SSD1963液晶控制器 1、SSD1963液晶控制器 2、SSD1963内部框图分析 3、8080写时序…

RK3568平台开发系列讲解(音视频篇)FFmpeg公共基础参数

🚀返回专栏总目录 文章目录 一、公共操作部分二、每个文件主要操作部分三、视频操作部分四、音频操作部分沉淀、分享、成长,让自己和他人都能有所收获!😄 📢当我们使用 FFmpeg 时,有一些贯穿 FFmpeg 各个组件的核心参数,在我们查看帮助信息时就可以看到,help 不带参…