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

本文主要是介绍牛客周赛 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 - kMap.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);}staticclass 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;
}

写在最后

在这里插入图片描述

这篇关于牛客周赛 Round 28 解题报告 | 珂学家 | 组合数学 + 离散化树状数组的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/607442

相关文章

hdu2241(二分+合并数组)

题意:判断是否存在a+b+c = x,a,b,c分别属于集合A,B,C 如果用暴力会超时,所以这里用到了数组合并,将b,c数组合并成d,d数组存的是b,c数组元素的和,然后对d数组进行二分就可以了 代码如下(附注释): #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<que

hdu4869(逆元+求组合数)

//输入n,m,n表示翻牌的次数,m表示牌的数目,求经过n次操作后共有几种状态#include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdlib.h>#includ

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

uva 10014 Simple calculations(数学推导)

直接按照题意来推导最后的结果就行了。 开始的时候只做到了第一个推导,第二次没有继续下去。 代码: #include<stdio.h>int main(){int T, n, i;double a, aa, sum, temp, ans;scanf("%d", &T);while(T--){scanf("%d", &n);scanf("%lf", &first);scanf

hdu 1166 敌兵布阵(树状数组 or 线段树)

题意是求一个线段的和,在线段上可以进行加减的修改。 树状数组的模板题。 代码: #include <stdio.h>#include <string.h>const int maxn = 50000 + 1;int c[maxn];int n;int lowbit(int x){return x & -x;}void add(int x, int num){while

uva 10025 The ? 1 ? 2 ? ... ? n = k problem(数学)

题意是    ?  1  ?  2  ?  ...  ?  n = k 式子中给k,? 处可以填 + 也可以填 - ,问最小满足条件的n。 e.g k = 12  - 1 + 2 + 3 + 4 + 5 + 6 - 7 = 12 with n = 7。 先给证明,令 S(n) = 1 + 2 + 3 + 4 + 5 + .... + n 暴搜n,搜出当 S(n) >=

uva 11044 Searching for Nessy(小学数学)

题意是给出一个n*m的格子,求出里面有多少个不重合的九宫格。 (rows / 3) * (columns / 3) K.o 代码: #include <stdio.h>int main(){int ncase;scanf("%d", &ncase);while (ncase--){int rows, columns;scanf("%d%d", &rows, &col

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

Codeforces Round #240 (Div. 2) E分治算法探究1

Codeforces Round #240 (Div. 2) E  http://codeforces.com/contest/415/problem/E 2^n个数,每次操作将其分成2^q份,对于每一份内部的数进行翻转(逆序),每次操作完后输出操作后新序列的逆序对数。 图一:  划分子问题。 图二: 分而治之,=>  合并 。 图三: 回溯: