atcoder abc372 启发式合并, dp

news2024/9/22 16:38:28

A delete

代码:

#include <bits.stdc++.h>

using namespace std;

int main() {
    string s;
    cin >> s;
    for(auto t: s) if(t != '.') cout << t;
}

B 3 ^ A

思路:三进制转换,可以参考二进制,先把当前可以加入的最大的3的幂次加入,这样一定可以凑出答案

代码:

#include <bits/stdc++.h>

using namespace std;

int main() {
    int n;
    cin >> n;
    vector<int> a;
    int tmp = n;
    while(tmp) {
        int l = 0, r = 10;
        while(l < r) {
            int mid = l + r + 1 >> 1;
            if(pow(3, mid) <= tmp) l = mid;
            else r = mid - 1;
        }
        tmp -= pow(3, l);
        a.push_back(l);
    }
    cout << a.size() << endl;
    for(auto t: a) cout << t << " ";
    return 0;
}

C Count ABC Again

思路:判断当前变化的位置对结果是否会产生影响,在询问前先计算有多少ABC, 每次变换位置x前后扫描一下[x - 2, x + 2]范围内是否有ABC,变换前有让cnt --, 变换后有让cnt ++

代码:

#include <bits/stdc++.h>
using namespace std;

int main() {
    int n, q;
    cin >> n >> q;
    vector<char> s(n + 1);
    for(int i = 1; i <= n; i ++ ) cin >> s[i];
    int cnt = 0;
    for(int i = 3; i <= n; i ++ )
        if(s[i - 2] == 'A' && s[i - 1] == 'B' && s[i] == 'C')
            cnt ++;
    
    while(q -- ) {
        int x;
        char c;
        cin >> x >> c;
        string t;
        t += s[max(1, x - 2)];
        t += s[max(1, x - 1)];
        t += s[x];
        string t1;
        t1 += s[max(1, x - 1)];
        t1 += s[x];
        t1 += s[min(n, x + 1)];
        string t2;
        t2 += s[x];
        t2 += s[min(n, x + 1)];
        t2 += s[min(n, x + 2)];
        if(t1 == "ABC" || t2 == "ABC" || t == "ABC") cnt --;
        s[x] = c;
        t = s[max(1, x - 2)];
        t += s[max(1, x - 1)];
        t += s[x];
        t1 = s[max(1, x - 1)];
        t1 += s[x];
        t1 += s[min(n, x + 1)];
        t2 = s[x];
        t2 += s[min(n, x + 1)];
        t2 += s[min(n, x + 2)];
        if(t1 == "ABC" || t2 == "ABC" || t == "ABC") cnt ++;
        cout << cnt << "\n";
    }
    return 0;
}

D buildings

思路:首先对于每个点i,我们可以很容易用单调栈求出第一个大于该点的位置j,因此点i只有在(j + 1, i)这个区间内对答案有贡献, 这里可以用差分的方式计算贡献

代码:

#include <bits/stdc++.h>
using namespace std;

int main() {
    int n;
    cin >> n;
    vector<int> a(n + 1);
    a[0] = 0x3f3f3f3f;
    for(int i = 1; i <= n; i ++ ) cin >> a[i];
    vector<int> pos(n + 1);
    stack<int> stk;
    stk.push(0);
    for(int i = 1; i <= n; i ++ ) {
        while(a[stk.top()] <= a[i]) stk.pop();
        pos[i] = stk.top();
        stk.push(i);
    }

    vector<int> ans(n + 1);
    for(int i = 1; i <= n; i ++ ) {
        ans[pos[i]] += 1;
        ans[i] -= 1;
    }
    
    for(int i = 1; i <= n; i ++ ) {
        ans[i] += ans[i - 1];
        cout << ans[i] << " ";
    }
    return 0;
}

E K-th Largest Connected Components

思路:注意到k很小,因此在查询的时候可以直接遍历。现在考虑如何存数据。可以用并查集合并两个集合,并且在合并的时候一定要将小的集合合并到大的集合中去,因为小集合合并到大集合中,最后的集合一定大于小集合元素数量的两倍,因此合并的时间复杂度不会超过logn

代码:
 

#include <bits/stdc++.h>
using namespace std;

const int N = 2e5 + 10;

struct node {
    int num;
    priority_queue<int> q;
    /*bool operator += (node W) const {
        while(!W.q.empty()) {
            q.push(W.q.top());
            W.q.pop();
        }
    }*/
}_size[N];
int p[N];

int find(int x) {
    if(x != p[x]) {
        p[x] = find(p[x]);
    }   
    return p[x];
}

int main() {
    int n, q;
    cin >> n >> q;
    for(int i = 1; i <= n; i ++ ) {
        p[i] = i;
        _size[i].num = 1;
        _size[i].q.push(i);
    }
    while(q -- ) {
        int op;
        cin >> op;
        if(op == 1) {
            int u, v;
            cin >> u >> v;
            int pu = find(u);
            int pv = find(v);
            if(pu != pv) {
                if(_size[pu].num >= _size[pv].num){
                    while(!_size[pv].q.empty()) {
                        _size[pu].q.push(_size[pv].q.top());
                        _size[pv].q.pop();
                    }
                    _size[pu].num += _size[pv].num;
                    p[pv] = pu;
                } else {
                    while(!_size[pu].q.empty()) {
                        _size[pv].q.push(_size[pu].q.top());
                        _size[pu].q.pop();
                    }
                    _size[pv].num += _size[pu].num;
                    p[pu] = pv;
                }
            }
        } else {
            int k, v;
            cin >> v >> k;
            auto q1 = _size[find(v)].q;
            for(int i = 1; i <= k - 1 && !q1.empty(); i ++ ) {
                q1.pop();
            }
            
            if(!q1.empty()) cout << q1.top() << endl;
            else cout << -1 << endl;
        }
    }
    return 0;
}
/*
2
1
-1
4
2
-1
*/

这里留下个疑问

int k, v;
            cin >> v >> k;
            auto q1 = _size[find(v)].q;
            for(int i = 1; i <= k - 1 && !q1.empty(); i ++ ) {
                q1.pop();
            }
            
            if(!q1.empty()) cout << q1.top() << endl;
            else cout << -1 << endl;

为什么在查询时直接查询_size[p[v]]答案会出错,是路径压缩不彻底的原因吗

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

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

相关文章

React 中的延迟加载

延迟加载是 Web 开发中的一种有效的性能优化技术&#xff0c;尤其是对于 React 等库和框架。它涉及仅在需要时加载组件或资源&#xff0c;无论是响应用户操作还是当元素即将在屏幕上显示时。这可以减少应用程序的初始加载时间&#xff0c;减少资源消耗&#xff0c;并改善用户体…

ETLCloud:新一代ETL数据抽取工具的定义与革新

数据集成、数据治理已经成为推动企业数字化转型的核心动力&#xff0c;现在的企业比任何时候都需要一个更为强大的新一代数据集成工具来处理、整合并转化多种数据源。 而ETL&#xff08;数据提取、转换、加载&#xff09;作为数据管理的关键步骤&#xff0c;已在企业数据架构中…

串口助手的qt实现思路

要求实现如下功能&#xff1a; 获取串口号&#xff1a; foreach (const QSerialPortInfo &serialPortInfo, QSerialPortInfo::availablePorts()) {qDebug() << "Port: " << serialPortInfo.portName(); // e.g. "COM1"qDebug() <<…

【JavaEE】——线程的安全问题和解决方式

阿华代码&#xff0c;不是逆风&#xff0c;就是我疯&#xff0c;你们的点赞收藏是我前进最大的动力&#xff01;&#xff01;希望本文内容能够帮助到你&#xff01; 目录 一&#xff1a;问题引入 二&#xff1a;问题深入 1&#xff1a;举例说明 2&#xff1a;图解双线程计算…

SwiftUI 实现关键帧动画

实现一个扫描二维码的动画效果&#xff0c;然而SwiftUI中没有提供CABasicAnimation 动画方法&#xff0c;该如何实现这种效果&#xff1f;先弄清楚什么关键帧动画&#xff0c;简单的说就是指视图从起点至终点的状态变化&#xff0c;可以是形状、位置、透明度等等 本文提供了一…

(done) 声音信号处理基础知识(3) (一个TODO: modulation 和 timbre 的关联)(强度、响度、音色)

来源&#xff1a;https://www.youtube.com/watch?vJkoysm1fHUw sound power 通常可以被认为是能量传输的速率 声源往所有方向传输的每时间单位能量 用 瓦特(W) 作为单位测量 Sound intensity 声音强度&#xff0c;每单位面积的 sound power W/m^2 人类实际上能听到非常小强…

八. 实战:CUDA-BEVFusion部署分析-coordTrans Precomputation

目录 前言0. 简述1. 案例运行2. coordTrans3. Precomputation总结下载链接参考 前言 自动驾驶之心推出的 《CUDA与TensorRT部署实战课程》&#xff0c;链接。记录下个人学习笔记&#xff0c;仅供自己参考 本次课程我们来学习下课程第八章—实战&#xff1a;CUDA-BEVFusion部署分…

Python Selenium 自动化爬虫 + Charles Proxy 抓包

一、场景介绍 我们平常会遇到一些需要根据省、市、区查询信息的网站。 1、省市查询 比如这种&#xff0c;因为全国的省市比较多&#xff0c;手动查询工作量还是不小。 2、接口签名 有时候我们用python直接查询后台接口的话&#xff0c;会发现接口是加签名的。 而签名算法我…

keil5 MDK 最新版本官网下载(v5.40为例) ARM单片机环境搭建安装教程(STM32系列为例)

正所谓授之以鱼不如授之以渔。本文将细讲从官网下载keil5MDK来保证keil5为最新版本的实时性 &#xff08;注意新老版本可能出现版本兼容问题&#xff0c;若不放心&#xff0c;跟着老弟我一起下载5.40版本即可&#xff09; 目录 一、下载keil5 MDK 方法①:CSDN下载&#xff0…

计算机毕业设计 基于 Hadoop平台的岗位推荐系统 SpringBoot+Vue 前后端分离 附源码 讲解 文档

&#x1f34a;作者&#xff1a;计算机编程-吉哥 &#x1f34a;简介&#xff1a;专业从事JavaWeb程序开发&#xff0c;微信小程序开发&#xff0c;定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事&#xff0c;生活就是快乐的。 &#x1f34a;心愿&#xff1a;点…

【深入学习Redis丨第六篇】Redis哨兵模式与操作详解

〇、前言 哨兵是一个分布式系统&#xff0c;你可以在一个架构中运行多个哨兵进程&#xff0c;这些进程使用流言协议来接收关于Master主服务器是否下线的信息&#xff0c;并使用投票协议来决定是否执行自动故障迁移&#xff0c;以及选择哪个Slave作为新的Master。 文章目录 〇、…

Django 5 学习笔记 2024版

1. 官方中文文档 Django 文档 | Django 文档 | Django (djangoproject.com) 2. 第一个应用 博客 总目录 <1>依赖安装: pip install django <2> 创建 工程 myapp django-admin startproject myapp cd myapp <3>创建 应用 app > python manage.py s…

算法-排序算法(冒泡选择插入希尔快速归并堆计算)

1.算法概述 1.1什么是算法 算法是特定问题的求解步骤的描述&#xff0c;是独立存在的一种解决问题的思想和方法。对于算法而言计算机编程语言并不重要&#xff0c;可以用任何计算机编程语言来编写算法。 程序数据结构算法 1.2数据结构和算法的区别和联系 数据结构只是静态…

CentOS 7 YUM源不可用

CentOS 7 操作系统在2024年6月30日后将停止官方维护&#xff0c;并且官方提供的YUM源将不再可用。 修改&#xff1a;nano /etc/yum.repos.d/CentOS-Base.repo # CentOS-Base.repo [base] nameCentOS-$releasever - Base baseurlhttp://mirrors.aliyun.com/centos/$rel…

数据库管理-第243期 云栖有感:AI?AI!(20240922)

数据库管理243期 2024-09-22 数据库管理-第243期 云栖有感&#xff1a;AI&#xff1f;AI&#xff01;&#xff08;20240922&#xff09;1 AI2 干货3 数据库总结 数据库管理-第243期 云栖有感&#xff1a;AI&#xff1f;AI&#xff01;&#xff08;20240922&#xff09; 作者&am…

Apache 中间件漏洞

CVE-2021-41773 环境搭建 docker pull blueteamsteve/cve-2021-41773:no-cgid 访问172.16.1.4:8080 使⽤curl http://172.16.1.4:8080/cgi-bin/.%2e/.%2e/.%2e/.%2e/etc/passwd

Linux中的调度算法

nice值的范围有限&#xff0c;即为[-20, 19]&#xff0c;也就是40个数字&#xff0c;优先级为[60, 99]即一共40个优先级 目前谈论的Linux操作系统叫做分时操作系统&#xff0c;调度的时候主要强调公平&#xff0c;还有一种是实时操作系统&#xff0c;比如智能汽车里面必须装有这…

网站设计中安全方面都需要有哪些考虑

网站设计中的安全性是一个多方面的问题&#xff0c;需要从多个角度进行考虑和实施。以下是一些关键的安全考虑因素&#xff1a; 数据加密&#xff1a; 使用SSL&#xff08;安全套接字层&#xff09;证书来建立加密连接&#xff0c;确保数据在传输过程中不被截获。定期更新SSL证…

学习IEC 62055付费系统标准

1.IEC 62055 国际标准 IEC 62055 是目前关于付费系统的唯一国际标准&#xff0c;涵盖了付费系统、CIS 用户信息系统、售电系统、传输介质、数据传输标准、预付费电能表以及接口标准等内容。 IEC 62055-21 标准化架构IEC 62055-31 1 级和 2 级有功预付费电能表IEC 62055-41 STS…

【重学 MySQL】三十七、聚合函数

【重学 MySQL】三十七、聚合函数 基本概念5大常用的聚合函数COUNT()SUM()AVG()MAX()MIN() 使用场景注意事项示例查询 聚合函数&#xff08;Aggregate Functions&#xff09;在数据库查询中扮演着至关重要的角色&#xff0c;特别是在处理大量数据时。它们能够对一组值执行计算&a…