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

牛客月赛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;
}

相关文章:

  • ZArchiver正版:高效文件管理,完美解压体验
  • javaEE——单例模式
  • 机器学习的简单介绍
  • 机器学习和深度学习的对比
  • word批量转pdf工具
  • 基于PHP实现的easy管理系统
  • Office 三大组件Excel、Word、Access 里 VBA 区别对比
  • Matlab/Simulink - BLDC直流无刷电机仿真基础教程(七) - 波形解析专题P2
  • MVC 安全
  • iview自定义下拉树菜单
  • 基于STM32的温湿度光照强度仿真设计(Proteus仿真+程序设计+设计报告+讲解视频)
  • nginx 正反向代理和nginx正则
  • Tire 树(字典树/前缀树)
  • Github2025-05-04php开源项目日报 Top10
  • 【Springboot进阶】springboot+mybatis+jsqlparser实现数据权限控制
  • RAGFlow 接入企业微信应用实现原理剖析与最佳实践
  • 【聚类分析】基于copula的风光联合场景生成与缩减
  • 【QT】QT中的网络编程(TCP 和 UDP通信)
  • JAVA:使用 MapStruct 实现高效对象映射的技术指南
  • Git从入门到精通-第四章-更新仓库
  • 经常犯困、迷糊……当心是身体发出的“黄牌”警告
  • 美国将于6月14日举行阅兵式,美媒报当天是特朗普生日
  • 力保夏粮丰收,粮食大省江苏多地党政主官到田间察看小麦长势
  • 几天洗一次头发最好?终于有答案了...
  • 生命与大海相连:他在300多米的深海行走,在沉船一线打捞救援
  • 来上海喝云南咖啡!上海国际咖啡文化节助力咖啡产业破圈出海