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


前言

在这里插入图片描述


整体评价

还是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;
}

写在最后

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【算法练习】leetcode算法题合集之数组和哈希表篇

重建数组&#xff08;高频&#xff09; LeetCode283.移动零 LeetCode283.移动零 双指针&#xff0c;记录已经处理好的序列的尾部 class Solution {public void moveZeroes(int[] nums) {int k 0;for (int i 0; i < nums.length; i) {if (nums[i] ! 0) {swap(nums, i, k)…

【前后端的那些事】开源!前后端环境搭建+树形结构表格实现

文章目录 1. 前后端项目环境搭建2. table-tree2.1 后端准备2.2 前端准备 前言&#xff1a;最近写项目&#xff0c;发现了一些很有意思的功能&#xff0c;想写文章&#xff0c;录视频把这些内容记录下。但这些功能太零碎&#xff0c;如果为每个功能都单独搭建一个项目&#xff0…

Python之Matplotlib绘图调节清晰度

Python之Matplotlib绘图调节清晰度 文章目录 Python之Matplotlib绘图调节清晰度引言解决方案dpi是什么&#xff1f;效果展示总结 引言 使用python中的matplotlib.pyplot绘图的时候&#xff0c;如果将图片显示出来&#xff0c;或者另存为图片&#xff0c;常常会出现清晰度不够的…

前端js写数据结构与算法

1、什么是数据结构与算法 数据结构&#xff1a;是指数据对象中数据元素之间的相互关系。包括集合结构、线性结构、树形结构、图形结构。 算法&#xff1a;解决问题的思路。 2、时间复杂度 1.是什么? 执行当前算法所“花费的时间” 2.干什么? 在写代码的过程中&#xf…

网工内推 | 信息安全主管,CISP/CISSP认证优先,最高25K

01 武汉华康世纪医疗股份有限公司 招聘岗位&#xff1a;网络安全主管 职责描述&#xff1a; 1、推进公司信息/网络安全管理体系规划、建设、持续改进&#xff0c;促进信息安全管理的推行落地,保障网络、系统与数据安全&#xff1b; 2、维护管理信息/网络管理软件&#xff0c;设…

CSP网络结构实战 - 降低计算量的特征融合方式

CSP网络结构实战 - 降低计算量的特征融合方式 CSP网络结构实战 - 降低计算量的特征融合方式0. 引言1. CSP网络结构简介1.1 核心思想1.2 解决的问题 2. 实验验证2.1 CSP网络模型构建2.2 数据读取与预处理2.3 模型训练与验证 3. 对比实验4. 结果与总结 CSP网络结构实战 - 降低计算…

RT-DETR算法优化改进:多层次特征融合(SDI)结合PConv、DualConv、GSConv,实现二次创新 | UNet v2最新论文

💡💡💡本文独家改进:多层次特征融合(SDI)高效结合DualConv、PConv、GSConv等实现二次创新 1)替代原始的Concat; RT-DETR魔术师专栏介绍: https://blog.csdn.net/m0_63774211/category_12497375.html ✨✨✨魔改创新RT-DETR 🚀🚀🚀引入前沿顶会创新(CVPR…

从零开始做题:逆向wdb_2018_2nd_easyfmt

1.题目信息 2.解题分析 格式化字符串漏洞 如何确定偏移 Do you know repeater? 输入AAAA.%p.%p.%p.%p.%p.%p.%p.%p.%p.%p.%p.%p. 输出AAAA.0xffffd658.0x64.0xf7ffdc08.0xf7ffcd00.0xffffd77c.0x41414141.0x2e70252e.0x252e7025.0x70252e70.0x2e70252e.0x252e7025.0x70252…

【数据结构】排序算法

&#x1f984;个人主页:修修修也 &#x1f38f;所属专栏:数据结构 ⚙️操作环境:Visual Studio 2022 目录 &#x1f38f;排序的定义 &#x1f38f;排序的稳定性 &#x1f4cc;稳定性的定义 &#x1f4cc;稳定性的意义 &#x1f38f;内排序与外排序 &#x1f38f;八大内排…

Linux环境基础开发工具的使用(上)

文章目录 Linux 软件包管理器 yum什么是软件包关于rzsz查看软件包安装软件卸载软件 Linux编辑器 - vimvim的基本概念vim下各模式的切换vim命令模式各命令汇总vim底行模式各命令汇总 配置vim Linux 软件包管理器 yum 什么是软件包 在Linux下安装软件, 一个通常的办法是下载到程…

Vue实战:两种方式创建Vue项目

文章目录 一、实战概述二、实战步骤&#xff08;一&#xff09;安装Vue CLI脚手架1、从Node.js官网下载LTS版本2、安装Node.js到指定目录3、配置Node.js环境变量4、查看node版本5、查看npm版本6、安装Vue Cli脚手架7、查看Vue Cli版本 &#xff08;二&#xff09;命令行方式构建…

Git与VScode联合使用详解

目录 Git与VScode联合使用 方式一 1. 用vscode打开文件夹&#xff0c;如图点击初始化仓库&#xff0c;把此仓库初始为git仓库。 2. 提交文件到本地仓库 3. vscode与github账号绑定 4. 在github中建立远程仓库 5. 本地仓库与远程仓库绑定 方式二 1. 在github上建立远程仓…

魅族MX4pro系统升级、降级

网上的教程都是按住开机键音量上或者下键&#xff0c;但是我按了没用&#xff0c;还是直接点击压缩包管用。 下载系统 官网地址&#xff08;所有手机固件&#xff09;&#xff1a;https://flyme.cn/firmware.html 官方魅族mx4Pro系统&#xff1a;https://flyme.cn/firmwarelis…

通过本质看现象:关于Integer受内部初始化赋值范围限制而出现的有趣现象

文/朱季谦 这是我很多年前的第一篇技术博客&#xff0c;当时作为一名技术小菜鸟&#xff0c;总体而言显得很拙见&#xff0c;但也算是成长路上的一个小脚印&#xff0c;希望能在以后的日子里&#xff0c;可以对JAVA技术有一个更加深入的思考与认识。 前几天我在逛论坛的时候&a…

《C++大学教程》4.14信用额度问题

题目&#xff1a; #include <iostream> #include <iomanip> using namespace std;int main() {unsigned int account;double beginning_balance, total_charges, total_credits, credit_limit;cout << "Enter account numbeu(or -1 to qiut):";cin…

18k+ start开源项目管理工具Focalboard centos部署教程

1.下载安装包 官方github地址 https://github.com/mattermost/focalboard 发行版下载地址 https://github.com/mattermost/focalboard/releases/download/v7.10.6/focalboard-server-linux-amd64.tar.gz 插件下载地址 https://github.com/mattermost/focalboard/releases/down…

【DB】MySQL版本5.7和8的区别,以及升级的注意事项

文章目录 1、MySQL版本5.7和8的区别2、MySQL 5.7升级8 1、MySQL版本5.7和8的区别 在数据库管理系统中&#xff0c;MySQL是一个广泛使用、开源的解决方案。它提供了强大的功能&#xff0c;同时具有优秀的性能和可扩展性。 MySQL 5的发布于2005年&#xff0c;在MySQL数据库的发…

MATLAB R2023a安装教程

鼠标右击软件压缩包&#xff0c;选择“解压到MATLAB.R2023a”。 打开解压后的文件夹&#xff0c;鼠标右击“R2023a_Windows_iso”选择“装载”。 鼠标右击“setup.exe”选择“以管理员身份运行”。 点击“高级选项”选择“我有文件安装密钥”。 点击“是”&#xff0c;然后点击…

【GitHub项目推荐--13 个 Python 学习资源】【转载】

近些年&#xff0c;人工智能应用铺天盖地。人脸识别、老照片复活、换脸等应用都得益于人工智能算法。 许多人工智能算法封装的框架基于 Python 语言&#xff0c;这也导致了 Python 的热度只增不减。 Python 简单易学&#xff0c;根据 2020 年 StackOverflow 开发者调查报告显…

50天精通Golang(第17天)

beego框架总结及数据库连接配置 一、beego框架总结 1.1 Beego项目组织架构 上节课程内容对beego的案例代码进行了一个简单的分析&#xff0c;总结一下beego项目的组织结构&#xff0c;总结如下&#xff1a; 1.1.1 项目配置&#xff1a;conf 项目配置文件所在的目录&#x…