牛客周赛 Round 28 解题报告 | 珂学家 | 组合数学 + 离散化树状数组

news2025/1/21 22:08:30

前言

在这里插入图片描述


整体评价

还是E稍微有点意思,新周赛好像比预期要简单一些, _.


欢迎关注

珂朵莉 牛客周赛专栏

珂朵莉 牛客小白月赛专栏


A. 小红的新周赛

思路: 模拟

#include <bits/stdc++.h>

using namespace std;

int main() {
    int res = 0;
    for (int i = 0; i < 6; i++) {
        int v;
        cin >> v;
        res += v;
    }
    cout << res << endl;
    return 0;
}

B. 小红的字符串

思路: 计数+模拟

引入 26 * 26的状态,进行计数

这有个好处,就是天然排序,避免大内存存字符串并排序

#include <bits/stdc++.h>

using namespace std;

int main() {
    
    // 26 * 26天然保序
    int cnt[26][26] = {0};
    
    string s;
    cin >> s;
    int n = s.length();
    for (int i = 0; i < n - 1; i++) {
        int p1 = s[i] - 'a';
        int p2 = s[i + 1] - 'a';
        cnt[p1][p2]++;
    }
    
    for (int i = 0; i < 26; i++) {
        for (int j = 0; j < 26; j++) {
            string ts = "";
            ts.push_back((char)(i + 'a'));
            ts.push_back((char)(j + 'a'));
            for (int t = 0; t < cnt[i][j]; t++) {
                cout << ts << endl;
            }
        }
    }
    
}

C. 小红的炸砖块

思路: 模拟

引入保存每列高度的数组,然后模拟即可

#include <bits/stdc++.h>

using namespace std;

int main() {
    
    int n, m, k;
    cin >> n >> m >> k;
    
    vector<int> cols(m, n);
    for (int i = 0; i < k; i++) {
        int r, c;
        cin >> r >> c;
        if (cols[c - 1] >= n - r + 1) {
            cols[c - 1]--;
        }
    }
    
    for (int i = 0; i < n; i++) {
        string r;
        for (int j = 0; j < m; j++) {
            r.push_back(cols[j] >= n - i ? '*' : '.');
        }
        cout << r << endl;
    }
    
    return 0;
}

D. 小红统计区间(easy)

思路: 滑窗

非常典的一道滑窗题,双指针维护即可

#include <bits/stdc++.h>

using namespace std;

using int64 = long long;

int main() {
    
    int n;
    int64 k;
    cin >> n >> k;
    
    vector<int64> pre(n + 1, 0);
    vector<int> arr(n);
    for (int i = 0; i < n; i++) {
        cin >> arr[i];
        pre[i + 1] = pre[i] + arr[i];
    }
    
    int64 res = 0LL;
    int j = 0;
    for (int i = 0; i < n; i++) {
        while (j <= i && pre[i + 1] - pre[j] >= k) {
            j++;
        }
        res += j;
    }
    cout << res << endl;
    
    return 0;
}

E. 小红的好数组

思路: 找规律 + 组合数学

case给的非常良心

可以分类讨论,大概有4种类似的序列

arr1 = [偶数,偶数,偶数,偶数,偶数,偶数, …]

arr2 = [奇数,奇数,偶数,奇数,奇数,偶数,…]

arr3 = [奇数,偶数,奇数,奇数,偶数,奇数,…]

arr4 = [偶数,奇数,奇数,偶数,奇数,奇数,…]

奇数/偶数的分布,呈现强烈的规律

最终为这4种情况的组合方案和

#include <bits/stdc++.h>

using namespace std;

using int64 = long long;

const int64 mod = (long)1e9 + 7;

int64 ksm(int64 b, int64 v) {
    int64 r = 1LL;
    while (v > 0) {
        if (v % 2 == 1) {
            r = r * b % mod;
        }
        v /= 2;
        b = b * b % mod;
    }
    return r;
}

int main() {
    
    int n, k;
    cin >> n >> k;
    
    int k2 = k / 2, k1 = k - k2;
    
    int64 r1 = ksm(k2, n);
    int64 r2 = ksm(k2, n/3) * ksm(k1, n - n/3) % mod;
    int64 r3 = ksm(k2, (n+1)/3) * ksm(k1, n - (n+1)/3) % mod;
    int64 r4 = ksm(k2, (n+2)/3) * ksm(k1, n - (n+2)/3) % mod;
    
    int64 res = (r1 + r2 + r3 + r4) % mod;
    cout << res << endl;
    
    return 0;
}

F. 小红统计区间(hard)

思路: 离散化+树状数组

也是一道非常典的题

因为存在负数,所以滑窗的基础已经被破坏了

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;

public class Main {

    static class BIT {
        int n;
        int[] arr;
        public BIT(int n) {
            this.n = n;
            this.arr = new int[n + 1];
        }

        int query(int p) {
            int res = 0;
            while (p > 0) {
                res += arr[p];
                p -= p & -p;
            }
            return res;
        }

        void update(int p, int d) {
            while (p <= n) {
                arr[p] += d;
                p += p & -p;
            }
        }
    }

    public static void main(String[] args) {
        AReader sc = new AReader();

        int n = sc.nextInt();
        long k = sc.nextLong();

        long[] arr = new long[n];
        long[] pre = new long[n + 1];
        for (int i = 0; i < n; i++) {
            arr[i] = sc.nextLong();
            pre[i + 1] = pre[i] + arr[i];
        }

        // 进行离散化
        TreeSet<Long> ids = new TreeSet<>();
        for (long v: pre) {
            ids.add(v);
        }
        int ptr = 0;
        TreeMap<Long, Integer> hp = new TreeMap<>();
        for (long kv: ids) {
            hp.put(kv, ++ptr);
        }

        BIT bit = new BIT(ptr);
        bit.update(hp.get(0l), 1);

        long res = 0;
        for (int i = 0; i < n; i++) {
            long p = pre[i + 1];
            // p - x >= k
            // x <= p - k
            Map.Entry<Long, Integer> ent = hp.floorEntry(p - k);
            if (ent != null) {
                res += bit.query(ent.getValue());
            }
            bit.update(hp.get(p), 1);
        }

        System.out.println(res);

    }

    static
    class AReader {
        private BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
        private StringTokenizer tokenizer = new StringTokenizer("");
        private String innerNextLine() {
            try {
                return reader.readLine();
            } catch (IOException ex) {
                return null;
            }
        }
        public boolean hasNext() {
            while (!tokenizer.hasMoreTokens()) {
                String nextLine = innerNextLine();
                if (nextLine == null) {
                    return false;
                }
                tokenizer = new StringTokenizer(nextLine);
            }
            return true;
        }
        public String nextLine() {
            tokenizer = new StringTokenizer("");
            return innerNextLine();
        }
        public String next() {
            hasNext();
            return tokenizer.nextToken();
        }
        public int nextInt() {
            return Integer.parseInt(next());
        }

        public long nextLong() {
            return Long.parseLong(next());
        }

//        public BigInteger nextBigInt() {
//            return new BigInteger(next());
//        }
        // 若需要nextDouble等方法,请自行调用Double.parseDouble包装
    }

}
#include <bits/stdc++.h>

using namespace std;
using int64 = long long;

class BIT {
private:
    int n;
    vector<int> arr;
public:
    BIT(int n): n(n), arr(n + 1, 0) {
    }

    int query(int p) {
        int r = 0;
        while (p > 0) {
            r += arr[p];
            p -= p & -p;
        }
        return r;
    }

    void update(int p, int d) {
        while (p <= n) {
            arr[p] += d;
            p += p & -p;
        }
    }
};

int main() {

    int n;
    int64 k;
    cin >> n >> k;

    vector<int64> pre(n + 1, 0LL);
    for (int i = 0; i < n; i++) {
        int v;
        cin >> v;
        pre[i + 1] = pre[i] + v;
    }

    set<int64> ts;
    for (int64 v: pre) {
        ts.insert(v);
    }
    int ptr = 0;
    map<int64, int> idMap;
    for (int64 v: ts) {
        idMap[v] = ++ptr;
    }

    int64 res = 0;
    BIT bit(ptr);
    bit.update(idMap[0], 1);
    for (int i = 0; i < n; i++) {
        int64 p = pre[i + 1];
        if (idMap.find(p - k) != idMap.end()) {
            res += bit.query(idMap[p - k]);
        } else {
            auto iter = idMap.lower_bound(p - k);
            if (iter != idMap.end()) {
                res += bit.query(iter->second - 1);
            } else {
                res += bit.query(ptr);
            }
        }
        bit.update(idMap[p], 1);
    }
    cout << res << endl;

    return 0;
}

写在最后

在这里插入图片描述

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

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

相关文章

基于Java SSM框架实现在线作业管理系统项目【项目源码】计算机毕业设计

基于java的SSM框架实现在线作业管理系统演示 JSP技术 JSP技术本身是一种脚本语言&#xff0c;但它的功能是十分强大的&#xff0c;因为它可以使用所有的JAVA类。当它与JavaBeans 类进行结合时&#xff0c;它可以使显示逻辑和内容分开&#xff0c;这就极大的方便了运动员的需求…

Java:常见算法

认识算法 什么是算法&#xff1f; 解决某个实际问题的过程和方法 学习算法的技巧 先搞清楚算法的流程直接去推敲如何写代码 排序算法 冒泡排序 每次从数组中找出最大值放在数组的后面去。 实现冒泡排序的关键步骤分析 确认总共需要做几轮&#xff1a;数组的长度-1每轮比较…

EMC VNXe / Unity存储系统如何找回密码

开始之前&#xff0c;先简单说说&#xff0c;EMC的VNXe存储之间的关系。 EMC的VNXe和Unity存储的操作系统OS是一样的&#xff0c;当然不是完全一样&#xff0c;但是架构是一样的&#xff0c;先推出的产品是VNXe&#xff0c;然后在这个基础上演进到了Unity&#xff0c;Unity XT…

CentOS系统中如何配置Nginx作为静态HTTP服务器

在CentOS系统中&#xff0c;Nginx是一个流行的Web服务器软件&#xff0c;它可以高效地提供静态HTTP服务。以下是在CentOS中配置Nginx作为静态HTTP服务器的步骤&#xff1a; 1. 安装Nginx 首先&#xff0c;您需要确保已安装Nginx。可以使用以下命令安装Nginx&#xff1a; bas…

机器学习~从入门到精通(三)梯度下降法

一、梯度下降法 # 梯度下降不是一种算法&#xff0c;是一种最优化方法 # 上节课讲解的梯度下降的案例 是一个简单的一元二次方程 # 最简单的线性回归&#xff1a;只有一个特征的线性回归&#xff0c;有两个theta # 二、在多元线性回归中使用梯度下降求解 三、### R…

机器学习~从入门到精通(二)线性回归算法和多元线性回归

为什么要做数据归一化 一、数据归一化&#xff1a; 1.最值归一化 2.均值方差归一化import numpy as npX np.random.randint(1,100,size100) X X.reshape(-1,2) X.shape X np.array(X,dtypefloat) X[:,0] (X[:,0]-np.min(X[:,0]))/(np.max(X[:,0])-np.min(X[:,0])) X[:,1]…

Mr_HJ / form-generator项目学习-增加自定义的超融组件(一)

更多ruoyi-nbcio功能请看演示系统 gitee源代码地址 前后端代码&#xff1a; https://gitee.com/nbacheng/ruoyi-nbcio 演示地址&#xff1a;RuoYi-Nbcio后台管理系统 更多nbcio-boot功能请看演示系统 gitee源代码地址 后端代码&#xff1a; https://gitee.com/nbacheng/n…

【python playwright 安装及验证】

python playwright pip install playwright pip install playwright -i http://mirrors.aliyun.com/pypi/simple/ playwright codegen -o script.py -b chromium --ignore-https-errors --viewport-size “2560,1440” --proxy-server “http://100.8.64.8:60497” https://w…

基于Docker的Nginx的安装与配置

基于Docker的Nginx的安装与配置 1 为Nginx创建一个容器1.1 学习docker run1.2 通过docker run为Nginx创建并启动一个容器 2 配置Nginx2.1 学习docker的bind mount技术2.2 在Nginx容器中找到想修改的文件所在的目录2.2.1 认识nginx.conf文件2.2.2 访问Nginx服务&#xff0c;默认…

光猫(无限路由器)插入可移动硬盘搭建简易版的NAS

1.场景分析 最近查询到了许多有关NAS的资料&#xff0c;用来替代百度云盘等确实有很多优势&#xff0c;尤其是具有不限速&#xff08;速度看自己配置&#xff09;、私密性好、一次投入后续只需要电费即可等优势。鉴于手上没有可以用的资源-cpu、机箱、内存等&#xff0c;查询到…

嵌入式软件面试之程序在存储器中的分布

Hi, 大家好&#xff0c;今天阿目分享的是一个嵌入式软件面试的常见问题&#xff0c;内存分布或者说程序在内存中的布局&#xff0c;我们写的程序是按照怎么的准则放在内存中的&#xff1f; 一般有操作系统的嵌入式设备&#xff0c;都会有一个Bootloader, 它负责在上电后初始化…

ubuntu18.04 TensorRT 部署 yolov5-7.0推理

文章目录 1、环境配置2、推理部分2.1、检测2.2、分类2.3、分割2.4、INT8 量化 1、环境配置 链接: TensorRT cuda环境安装 2、推理部分 下载yolov5对应版本的包 https://github.com/wang-xinyu/tensorrtx/tree/master/yolov5 2.1、检测 1、源码模型下载 git clone -b v7.0 …

算法通关村第十六关—滑动窗口与堆结合(黄金)

滑动窗口与堆结合 堆与滑动窗口问题的结合 LeetCode239给你一个整数数组nums,有一个大小为k的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的k个数字。滑动窗口每次只向右移动一位&#xff0c;返回滑动窗口中的最大值。  对于最大值、K个最大这种场…

Multi-View-Information-Bottleneck

encoder p θ ( z 1 ∣ v 1 ) _θ(z_1|v_1) θ​(z1​∣v1​)&#xff0c;D S K L _{SKL} SKL​ represents the symmetrized KL divergence. I ˆ ξ ( z 1 ; z 2 ) \^I_ξ(z_1; z_2) Iˆξ​(z1​;z2​) refers to the sample-based parametric mutual information estimatio…

原子类-入门介绍和分类说明、基本类型原子类

Atomic翻译成中文是原子的意思。在化学上,我们知道原子是构成一般物质的最小单位,在化学 反应中是不可分割的。在我们这里Atomic是指一个操作是不可中断的。即使是在多个线程一起执 行的时候,一个操作一旦开始,就不会被其他线程干扰。 基本类型原子类 AtomicInteger:整…

Modelsim10.4安装

简介&#xff08;了解&#xff0c;可跳过&#xff09; modelsim是Mentor公司开发的优秀的HDL语言仿真软件。 它能提供友好的仿真环境&#xff0c;采用单内核支持VHDL和Verilog混合仿真的仿真器。它采用直接优化的编译技术、Tcl/Tk技术和单一内核仿真技术&#xff0c;编译仿真速…

P5461 赦免战俘题解

题目 现有2n2n(n≤10) 名作弊者站成一个正方形方阵等候kkksc03的发落。kkksc03决定赦免一些作弊者。他将正方形矩阵均分为4个更小的正方形矩阵&#xff0c;每个更小的矩阵的边长是原矩阵的一半。其中左上角那一个矩阵的所有作弊者都将得到赦免&#xff0c;剩下3个小矩阵中&…

【存储过程和存储函数】MySQL

存储过程和存储函数 一、实验目的 掌握通过SQL语句CREATE PROCEDURE创建存储过程的方法。 掌握使用SQL语句CALL调用存储过程的方法。 掌握使用SQL语句ALTER PROCEDURE修改存储过程的方法。 掌握使用SQL语句DROP PROCEDURE删除存储过程的方法。 掌握使用CREATE FUNCTION创建…

信息检索速通知识点

仅仅是我自己能想到的对这个分类的一个记忆。欢迎指正 首先&#xff0c;最重要的一点&#xff0c;什么是信息检索&#xff1f; 信息检索是从大规模无规则的数据中&#xff08;主要是文档&#xff09;中查询用户所需要的信息的过程。 然后&#xff0c;信息检索有哪几种索引呢&am…