首页 > 其他分享 >Day 23 - 模拟赛

Day 23 - 模拟赛

时间:2024-07-30 13:39:47浏览次数:14  
标签:le 23 int text long MAXN include Day 模拟

百万富翁的第二次实验

题目描述

马克吐温有一本非常著名的小说《百万英镑》,这本小说中主角最后归还了百万英镑给两位富翁。但结果就是两位富翁依然有无穷的问题需要进行社会实验,于是,他们打算进行第二次社会实验。那就是不同财富值的人在一场舞会上会发生什么事情。为了满足自己的好奇,百万富翁们邀请了全伦敦所有人来自己的舞会。舞会开始后他们就后悔了,因为来的人太多了,而且很多人的财富都相同,统计起来太费事了。所以百万富翁们找到你,希望你根据来舞会的时间,找出在一段时间内,来舞会的所有人财富值都互不相同的人数。

输入格式

第一行输入一个 \(n\) 表示有 \(n\) 个人参与舞会。

按照时间顺序输入 \(n\) 个人的财富值。

输出格式

输出在一段时间内参加舞会的所有人财富值都互不相同的人数的最大值。

\(\text{input1}\)

7
2 3 4 5 5 6 7

\(\text{output1}\)

4

数据范围

对于 \(100\%\) 的数据保证:每个人的财富值不超过 \(10^{11}\),\(0 \le n \le 10^6\)

#include<iostream>
#include<cmath>
#include<map>
using namespace std;
#define MAXN 1000005

long long n, a[MAXN], ans = 0;
map<long long, int> mp;

int main() {
    ios::sync_with_stdio(0);
    cin.tie(0); cout.tie(0);
    cin >> n;
    for(int i = 1; i <= n; i ++) cin >> a[i];
    long long l = 1, r = 1;
    while(r <= n) {
        if(!mp[a[r]]) mp[a[r]] ++;
        else {
            mp[a[r]] ++;
            while(a[l] != a[r]) mp[a[l]] --, l ++;
            mp[a[l]] --, l ++;
        }
        ans = max(ans, r - l + 1); r ++;
    }
    cout << ans << "\n";
    return 0;
}

magic

题目描述

输入格式

输出格式

\(\text{input1}\)

7 1
1 6 5 3 2 8 9
4 37

\(\text{output1}\)

2

样例解释

数据范围

\(\text{UpDate}\):\(p_i\) 范围更改为 \(1 \le p_i \le 10^8\)。

#include<iostream>
#include<algorithm>
using namespace std;
#define MAXN 500005

long long n, m, a[MAXN], ap[MAXN], ar[MAXN], aq[MAXN], p, q;

bool cmp(long long x, long long y) { return x > y; }

long long check(long long mid) { return a[1] * p * mid - ar[mid] * p - aq[mid]; }

int main() {
    ios::sync_with_stdio(0);
    cin.tie(0); cout.tie(0);
    cin >> n >> m;
    for(int i = 1; i <= n; i ++) cin >> a[i];
    sort(a + 1, a + n + 1, cmp);
    for(int i = 1; i <= n; i ++) 
        ar[i] = ar[i - 1] + a[1] - a[i], aq[i] = aq[i - 1] + (i - 1) * a[i];
    while(m --) {
        cin >> p >> q;
        long long l = 1, r = p, ans = -1; 
        while(l <= r) {
            long long mid = (l + r) >> 1;
            if(check(mid) >= q) ans = mid, r = mid - 1;
            else l = mid + 1;
        }
        cout << ans << "\n";
    }
    return 0;
}

统计区间

题目描述

有一个长度为 \(n\) 的数列 \(\{a_i\}\),\(a_i \in [1, n]\) 中,现在要统计区间中出现的数都恰好出现 \(2\) 次的区间数。

输入格式

第一行一个整数 \(n\)。

第二行 \(n\) 个整数表示 \(a_i\)。

输出格式

一行一个整数,表示满足条件的区间数.

\(\text{input1}\)

7
5 3 5 5 4 4 3

\(\text{output1}\)

4

数据范围

对于 \(30\%\) 的数据保证:\(1 \le n \le 10^3\)。

对于 \(100\%\) 的数据保证:\(1 \le n \le 10^6\)。

#include<iostream>
using namespace std;
#define MAXN 1005

long long n, a[MAXN], cnt[MAXN][MAXN], mp[MAXN], ans = 0;

int main() {
    ios::sync_with_stdio(0); 
    cin.tie(0); cout.tie(0);
	cin >> n; 
    for(int i = 1; i <= n; i ++) cin >> a[i];
    for(int i = 1; i <= n; i ++) for(int j = 1; j <= n; j ++) 
        cnt[i][j] = cnt[i - 1][j] + (a[i] == j);
    for(int l = 1; l <= n; l ++) 
        for(int r = l + 1; r <= n; r += 2) {
            bool f = true;
            for(int i = l; i <= r; i ++) 
                if(cnt[r][a[i]] - cnt[l - 1][a[i]] != 2) { f = false; break; }
            ans += f;
        }
    cout << ans << "\n";
    return 0;
}

柱形图

题目描述

输入格式

输出格式

\(\text{input1}\)

5
5 3
4 4
2 1
3 2
1 5

\(\text{output1}\)

24

\(\text{input2}\)

6
3 1
2 1
2 2
2 3
1 1
2 2

\(\text{output2}\)

8

\(\text{input3}\)

5
15 19
5 6
1 13
3 7
1 2

\(\text{output3}\)

285

样例解释

样例 \(1\) 解释:见题目描述中的图。

数据范围

本题采用捆绑测试。

#include<iostream>
#include<cmath>
using namespace std;
#define MAXN 200005

long long n, a[MAXN][18], b[MAXN][18], lg[MAXN] = { -1 }, ans = 0;

long long query1(long long l, long long r) {
    long long len = lg[r - l + 1];
    long long ans = min(a[l][len], a[r - (1 << (len)) + 1][len]);
    return ans;
}

long long query2(long long l, long long r) {
    long long len = lg[r - l + 1];
    long long ans = min(b[l][len], b[r - (1 << (len)) + 1][len]);
    return ans;
}

int main() {
    ios::sync_with_stdio(0); 
    cin.tie(0); cout.tie(0);
    cin >> n;
    for(int i = 1; i <= n; i ++) { cin >> a[i][0] >> b[i][0]; lg[i] = lg[i / 2] + 1; }
    for(int i = 1; i <= lg[n]; i ++) for(int j = 1; j + (1 << i) - 1 <= n; j ++) 
        a[j][i] = min(a[j][i - 1], a[j + (1 << (i - 1))][i - 1]), 
        b[j][i] = min(b[j][i - 1], b[j + (1 << (i - 1))][i - 1]);
    for(int l = 1; l <= n; l ++) for(int r = l; r <= n; r ++) 
        ans = max(ans, (r - l + 1) * query1(l, r) * query2(l, r));
    cout << ans << "\n";
    return 0;
}

\[100 + 100 + 30 + 20 = 250 \]

标签:le,23,int,text,long,MAXN,include,Day,模拟
From: https://www.cnblogs.com/So-noSlack/p/18332172

相关文章

  • APP逆向 day24unidbg上
    一.前言今天开始讲app逆向最后一个也是最重要的unidbg,这已经是从初级进阶到中级的了,我会讲unidbg,讲三节课,分为上中下来和大家讲(由简单到难逐步),这节课主要是和大家讲unidbg的介绍并且会结合之前讲的简单案例来让大家理解,如果过程中不太记得之前的位置定位,可以去看之前的课程,在......
  • day11 Java基础——基本运算符
    day11Java基础——基本运算符小技巧:CTRL+D复制当前行到下一行例1:packageoperator;publicclassDemo01{publicstaticvoidmain(String[]args){//二元运算符inta=10;intb=20;intc=25;intd=25;......
  • 排球比赛计分程序模拟冲刺(sprint)
    模拟冲刺计划(spring)选择小的用户故事模拟冲刺:裁判张三、业余排球比赛组织者李四、排球运动员王五一、任务拆分与开发时间: 裁判张三: 任务1:开发操作指南和演示视频-时间:第1天  任务2:实现提前设置比赛基本信息功能-时间:第2天  任务3:设计简便计分操作界面......
  • 代码随想录day14 || 226 翻转二叉树,101 对称二叉树, 104 二叉树的最大深度, 111 二叉树
    226翻转二叉树funcinvertTree(root*TreeNode)*TreeNode{ //思考,广度优先遍历,对于每一层,翻转其左右子节点 ifroot==nil{ returnnil } queue:=list.New() queue.PushBack(root) size:=1//存储每一层的节点个数 forqueue.Len()>0{ varcountint ......
  • 2024.7.26模拟赛8
    模拟赛抽象比赛,含金量最高的是题目背景?好像还是连续的。。。T1SameIntegers题目背景签到题,因为只有加操作,目标是将两个较小的数加成最大的。根据差的奇偶判断能否加二得到,如果不能先加一调一下。(简单题,题解抽象一点也没事吧)code#include<bits/stdc++.h>usingname......
  • Day14 二叉树Part2 递归的应用(二叉树相关)
    任务226.翻转二叉树给你一棵二叉树的根节点root,翻转这棵二叉树,并返回其根节点。思路逻辑上,我们知道用递归遍历一棵树,一定会遍历每个节点。因此在遍历的过程中处理即可。考虑递归基,即当节点为空时直接返回。考虑单层递归,为了反转二叉树,如何处理当前节点呢?即如何反转以当......
  • macOS Sonoma 14.6 (23G80) 正式版发布,ISO、IPSW、PKG 下载
    macOSSonoma14.6(23G80)正式版发布,ISO、IPSW、PKG下载2024年7月30日凌晨,macOSSonoma14.6发布,本更新提供了重要的错误修复和安全更新,建议所有用户安装。同时带来了macOSVentura13.6.8和macOSMonterey12.7.6安全更新。请访问原文链接:https://sysin.org/blog/......
  • 2024.7.25模拟赛7
    模拟赛疯狂补题解/改题中。。。T1[Permutations&Primes](未找到)构造一个\(1-n\)的序列,使所有区间中\(mex\)为质数的最多。感觉题不是很好。结论是:\(1\)放中间,\(2,3\)放两边。打标找规律,感性证明也挺显然的。nocodeT2SpreadofInformation首先看道典题:消......
  • [OI] 模拟退火
    模拟退火是一种适合求样本点较大的多峰函数极值的方法.模拟退火有几个参数:初始温度(\(T_{0}\)),终止温度(\(T_{e}\))和降温参数\(d\),具体地,模拟退火是让每次的当前温度\(T\)变为\(d\timesT\),直到终止,因此\(T_{e}\)应为一个很接近\(0\)的正数,\(d\)应该为一个很接近\(1\)的......
  • 有什么方法可以将模拟对象伪装成 Qt 方法参数中可接受的 PyQt 对象吗?
    这是MRE。您需要pytest安装...事实上pytest-qt不会造成任何伤害。importsys,pytestfromPyQt5importQtWidgetsfromunittestimportmockclassMyLineEdit(QtWidgets.QLineEdit):def__init__(self,parent):super().__init__(paren......