基本算法--蓝桥杯备考

1.前缀和

1.定义

假设有一个数组a[n],要计算它的前j个元素的和为

a[0]+a[1]+...+a[j-1]

时间复杂度为O(j),且随着j的变大时间复杂度越来越大。

使用了前缀和算法则为

sum[j]-sum[j-1]

时间复杂度是O(1),且数据越大优势越明显。

2.例题一

详解见《可获得的最小取值》详解

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
const int N = 200010;
long long a[N], sum[N];
int main()
{int n, k;cin >> n >> k;for (int i = 0; i < n; i++){cin >> a[i];}sort(a, a + n);for (int i = 1; i <= n; i++)//sum的下标表示的是前几位的和,所以i不能从0开始,否则sum会越界{sum[i] = sum[i - 1] + a[i-1];}long long ans = 1e18;for (int p = 1; p <= k; p++)//i初值为1的道理与上相同{ans = min(sum[n] - sum[n + p - k] + sum[2 * p], ans);}cout << ans;return 0;}

3.例题二

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
const int N =100005;
long long a[N], sum[N];
int main()
{//long long int x=0;//存储最终结果int n;cin >> n;for (int i = 0; i < n; i++){cin >> a[i];}for (int i = 1; i <= n; i++){sum[i] = sum[i - 1] + a[i-1];}long long int ans = 1e18;for (int i = 0; i < n; i++)//去掉=,省下一次计算量{ans = min(max(sum[i],(sum[n]-sum[i])),ans);}cout << ans;
}

4.例题三

异或:相同为0,不同为1

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

pgsql 中各个字符串的区别

PostgreSQL 提供了多种字符串类型&#xff0c;它们在存储方式、长度限制和适用场景上有所不同。以下是主要字符串类型的详细对比和区别&#xff1a; 一、核心字符串类型对比 CHAR(n)/CHARACTER(n) 特点&#xff1a;固定长度字符串&#xff0c;不足部分用空格填充最大长度&…

ubuntu中lightdm干嘛的?

在 Ubuntu 或其他 Linux 发行版中&#xff0c;LightDM 是一个轻量级的 显示管理器&#xff08;Display Manager&#xff09;&#xff0c;负责图形化登录界面、用户认证和会话启动。以下是它的核心作用、特点及类似替代品的对比&#xff1a; 1. LightDM 的核心作用 功能说明图形…

GraphQL注入 -- GPN CTF 2025 Real Christmas

part 1 服务器会每段时间禁用已注册的账号,此处存在漏洞 def deactivate_user_graphql(email):graphql_endpoint current_app.config["GRAPHQL_ENDPOINT"]query f"""mutation {{deactivateUser (user: {{email: "{email}"}}){{ success…

【机器学习深度学习】非线性激活函数

目录 前言 一、什么是激活函数&#xff1f; 1.1 作用 二、如果没有激活函数&#xff0c;会发生什么&#xff1f; 2.1 先看一张图理解“线性”的局限 2.2 核心认知&#xff1a;为什么非线性如此重要&#xff1f; 三、非线性激活函数到底解决了什么问题&#xff1f; 1. 引…

国外开源客服系统chathoot部署,使用教程

目录 一、系统版本要求&#xff1a; 二、部署步骤 2.1 安装docker 和docker-compose 2.2 准备docker-compose.yaml 2.3 初始化数据库 2.4 安装nginx 2.6 启动项目 三、使用教程 一、系统版本要求&#xff1a; linux ubuntu 22.042核4G 40GB&#xff08;或以上&#xf…

什么是回归测试?什么时候需要做回归测试?

回归测试详解&#xff1a;概念、时机与最佳实践 1. 什么是回归测试&#xff1f; 回归测试&#xff08;Regression Testing&#xff09; 是指在对软件进行修改&#xff08;如修复Bug、新增功能、优化代码&#xff09;后&#xff0c;重新执行已有测试用例&#xff0c;以确保&am…

Android-Layout Inspector使用手册

Layout Inspector Android Layout Inspector 是 Android Studio 中用于调试应用布局的工具 启动方法&#xff1a; 通过下载Layout Inspector插件&#xff0c;在 “View - Tool Windows - Layout Inspector” 或 “Tools - Layout Inspector” 启动。 主要界面区域&#xff1a…

postgreSQL 数据库字典导出工具

为满足项目验收文档需求&#xff0c;开发了一个基于Python的PostgreSQL数据字典导出工具。 废话不多说&#xff0c;先分享一下 软件截图 数据字典文件样式,文件格式为docx 软件源码 基于python开发&#xff0c; import tkinter as tk from tkinter import ttk, messagebox …

【AI解析】 CppNumericalSolvers:一个现代化的 C++17 纯头文件优化库 示例代码解析

一个轻量级仅头文件的 C17 库&#xff0c;提供针对&#xff08;无&#xff09;约束非线性函数及表达式模板的数值优化方法 https://github.com/PatWie/CppNumericalSolvers CppNumericalSolvers 库 include 目录下的文件及其功能说明 根目录文件 文件名功能说明function.h(主函…

第3篇:Gin的请求处理——获取客户端数据(Gin文件上传,接收JSON数据)

引言&#xff1a;Context是Gin的"瑞士军刀" 在Gin框架中&#xff0c;Context就像一把多功能的瑞士军刀&#xff0c;封装了所有与请求相关的操作。新手开发者常犯的错误是只把它当作参数传递的工具&#xff0c;却忽略了它强大的数据处理能力。 想象一个场景&#xf…

启动hardhat 项目,下载依赖的npm问题

Windows 环境 Hardhat 依赖安装问题排查指南 &#x1f6a8; 问题描述 在 Windows 环境下安装 Hardhat 项目依赖时&#xff0c;遇到以下错误&#xff1a; npm ERR! code ETARGET npm ERR! notarget No matching version found for nomicfoundation/edr^0.11.1. npm ERR! nota…

大数据里的拉链表:数据版本管理的时间胶囊

哈喽各位数据打工人&#xff5e;今天咱们来聊聊大数据领域一个超实用的神器 ——拉链表&#xff01;听起来像时尚单品&#xff1f;NoNoNo&#xff0c;它可是数据仓库里管理历史数据的宝藏工具✨ 就算你是刚入门的小白也能轻松听懂&#xff0c;咱们全程少玩比喻多讲人话&#xf…

docker执行yum报错Could not resolve host: mirrorlist.centos.org

解决办法&#xff1a; -- 依次执行以下命令cd /etc/yum.repos.d/sed -i s|#baseurlhttp://mirror.centos.org|baseurlhttp://vault.centos.org|g /etc/yum.repos.d/CentOS-*sed -i s/mirrorlist/#mirrorlist/g /etc/yum.repos.d/CentOS-*yum update -yecho "export LC_ALL…

JVM OutOfMemoryError原因及排查解决方案

在Java后端开发中&#xff0c;java.lang.OutOfMemoryError&#xff08;简称OOM&#xff09;是一个令开发者头疼的异常。它通常意味着Java虚拟机&#xff08;JVM&#xff09;在尝试分配新对象时&#xff0c;发现堆中没有足够的空间来容纳该对象&#xff0c;或者其他内存区域耗尽…

吐槽之前后端合作开发

大家好&#xff0c;我是佳瑞&#xff0c;从事10多年java开发程序员&#xff0c;爆照一张&#xff0c;存活互联网。 也做过vue开发自己的网站&#xff0c;觉得前端是真比后端开发轻松很多&#xff0c;就是画页面调样式&#xff0c;打包发布&#xff0c;当然不说是高级源码修改…

Oracle LogMiner日志分析工具介绍

Oracle LogMiner日志分析工具介绍 LogMiner使用须知LogMiner字典使用online catalog作为日志挖掘字典使用redo日志文件作为日志挖掘字典使用文本文件作为日志挖掘字典Redo日志文件自动获取日志文件手动获取日志文件启动LogMiner进行分析V$LOGMNR_CONTENTS视图LogMiner使用须知 …

2-4 Dockerfile指令(个人笔记)

以下指令基于 ubuntu Dockerfile整体示例 From&#xff1a;设置基础镜像 Maintainer &#xff1a;镜像维护者信息 COPY/ADD&#xff1a;添加本地文件到镜像中 WorkDir&#xff1a;设置工作目录 Run&#xff1a;执行命令 CMD/EntryPoint&#xff1a;配置容器启动时执行的命令

Redis主从架构哨兵模式

文章目录 概述一、主从搭建实例二、主从同步原理三、哨兵架构3.1、搭建哨兵架构3.2、演示故障恢复3.3、哨兵日志 概述 在生产环境下&#xff0c;Redis通常不会单机部署&#xff0c;为了保证高可用性&#xff0c;通常使用主从模式或集群架构&#xff0c;同时也面临着一些问题&am…

基于深度学习yolov5的安全帽实时识别检测系统

摘要&#xff1a;在现代工业和建筑行业中&#xff0c;确保员工的安全是至关重要的一环。安全帽作为一项基础的个人防护设备&#xff0c;对于降低头部受伤的风险发挥着关键作用。然而&#xff0c;确保工作人员在施工现场始终正确佩戴安全帽并非易事。传统的人工检查方法不仅效率…

GitLab 18.1 发布 Runner、无效的个人访问令牌查看等功能,可升级体验!

GitLab 是一个全球知名的一体化 DevOps 平台&#xff0c;很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab 是 GitLab 在中国的发行版&#xff0c;专门为中国程序员服务。可以一键式部署极狐GitLab。 学习极狐GitLab 的相关资料&#xff1a; 极狐GitLab 官网极狐…