当前位置: 首页 > java >正文

牛客月赛115 C题-命运之弹 题解

原题链接

https://ac.nowcoder.com/acm/contest/107879/C

题目描述

在这里插入图片描述

解题思路

记录每个数字出现的次数。枚举使用「转瞬即逝」的位置,统计后边比当前数字更大的数的数量,进而统计、更新答案。
详细细节见代码,代码里有详细的注释解释。

代码(CPP)

#include <bits/stdc++.h>
using namespace std;
using ll = long long;
using ull = unsigned long long;
#define endl "\n"
const int maxn = 2e5 + 10;
const int INF = 1e9;
int a[maxn], num[maxn], n;void solve() {cin >> n;for (int i = 1; i <= n; i++) {cin >> a[i];}int q;cin >> q;int v;      // 初始幸运值cin >> v;// 计数for (int i = 1; i <= n; i++) {num[a[i]]++;}// 枚举使用「转瞬即逝」的位置,统计后边比当前数字更大的数的数量即可int ans = INF;int cnt = 0;    // 统计前面大于v的数的个数for (int i = 1; i <= n; i++) {num[a[i]]--;// 统计后边比当前数字a[i]更大的数的数量即可int sum = 0;for (int j = a[i] + 1; j <= 100; j++) {sum += num[j];}// 统计答案,如果将当前数使用转瞬即逝,则本次代价为前面大于v的数的个数加上后边大于a[i]的数的数量ans = min(ans, sum + cnt);// 统计前面大于v的数的个数if (a[i] > v) cnt++;}cout << ans << endl;
}int main() {
//     freopen("in.txt", "r", stdin);ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);cout << fixed;cout.precision(18);solve();return 0;
}
http://www.xdnf.cn/news/3880.html

相关文章:

  • Linux环境下的进程创建、退出和进程等待
  • 谷歌 NotebookLM 支持生成中文播客
  • n8n 条件节点详解:IF 与 Switch 的多分支工作流设计
  • 虚函数VS虚拟继承:C++多重继承二义性破解与性能调优
  • 论快乐的学习和学习的快乐
  • 万字详解ADC药物Payload
  • Debezium 架构详解与实战示例
  • 【操作系统】深入理解内存管理:从虚拟内存到OOM Killer
  • cloudfare+gmail 配置 smtp 邮箱
  • 【CISCO】Se2/0, Se3/0:串行口(Serial) 这里串口的2/0 和 3/0分别都是什么?
  • React hooks详解
  • 快速外网访问,证书自动续约 | 极空间IPv4IPv6 DDNS 配置详解
  • 数据结构与算法:回溯
  • Python:Seaborn 美化图表的技术指南
  • 【五一培训】Day 4
  • 常用命令集合
  • PCB叠层设计方案
  • 探秘DeepSeek模型参数:解锁AI潜能的密码
  • GenCLS++:通过联合优化SFT和RL,提升生成式大模型的分类效果
  • Python之学习笔记(六)
  • Prompt compress 技术探究-LLMLingua
  • SpringAi接入DeepSeek大模型
  • SurfSense开源程序是NotebookLM / Perplexity / Glean的开源替代品,连接到外部来源,如搜索引擎
  • ArrayList的扩容机制(源码解析)
  • 深度学习的简单介绍
  • PISI:眼图1:眼图相关基本概念
  • 使用synchronized关键字同步Java线程
  • AndroidLogger常用命令和搜索功能介绍
  • STM32Cube-FreeRTOS任务调度与任务管理-笔记
  • ruoyi-flowable框架关于启动时提示锁住问题