【C++】求第二大的数详细解析


在这里插入图片描述

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳]
本文专栏: C++

文章目录

  • 💯前言
  • 💯题目描述
  • 💯输入描述
  • 💯解题思路分析
    • 1. 题目核心要求
    • 2. 代码实现与解析
    • 3. 核心逻辑逐步解析
      • 定义并初始化变量
      • 遍历并处理输入数据
      • 更新最大值与次大值
      • 输出结果
    • 4. 示例分析
      • 示例输入
      • 示例输出
      • 数据处理过程
  • 💯高级拓展与优化分析
    • 时间与空间复杂度
    • 潜在错误与改进方向
    • 数学与工程意义
  • 💯多种解法的对比与讨论
    • 排序法
    • 分治法
  • 💯小结


在这里插入图片描述


💯前言

  • 计算机科学和算法设计领域,如何以最优的方式处理有限的资源和数据一直是一个重要的研究课题。针对这一问题,本次探讨围绕一个经典的编程挑战展开:寻找数列中的次大值。本题虽然在描述上简洁,但通过限制变量和数据结构的使用,从而将重点放在动态维护状态变量优化算法性能上。这不仅为基础算法设计提供了宝贵的训练机会,同时也为解决实际工程中的资源约束问题提供了可借鉴的思路。
    本次分析将从题目背景算法设计代码实现扩展优化多解法对比等多个角度,系统地探讨这一问题的本质及其实现方法。
    C++ 参考手册
    在这里插入图片描述

💯题目描述

在这里插入图片描述
数学里有一个函数定义为 max(a, b),它返回 a 和 b 中较大的那个值。基于这一定义,现要求完成一个函数 max2,旨在从当前已经处理过的所有输入数字中,返回次大值。

需要注意的是,本题对代码实现有如下明确限制:

  • 只能使用两个全局变量 a1a2 分别记录当前最大值和次大值。
  • 不允许使用数组或其他结构存储所有输入的数字。
  • 允许额外使用两个局部变量用于存储整数个数 n 和当前输入的整数。

💯输入描述

在这里插入图片描述
第一行输入一个整数 n,表示有 n 个正整数满足 2 ≤ n ≤ 100 2 \leq n \leq 100 2n100

第二行输入 n 个互不相等的正整数。

输出描述
输出仅包含一个整数,即输入数列中的次大值。

示例1
输入:

10
10 9 8 7 6 5 4 3 2 1

输出:

9

💯解题思路分析

在这里插入图片描述


1. 题目核心要求

在这里插入图片描述
本题的核心在于从输入数据中以高效方式求解次大值,同时遵守以下条件约束:

  • 输入正整数各不相同,保证了最大值和次大值的存在性。
  • 只能使用两个变量 a1a2 存储结果状态,考验算法设计对空间资源的优化。
  • 需要保证算法能够在线性时间内完成计算,即时间复杂度为 O ( n ) O(n) O(n)

2. 代码实现与解析

以下是问题的完整代码实现:

#include <iostream>
using namespace std;
#include <climits>

void max2() {
    int n;
    cin >> n; // 读取正整数个数

    int a1 = INT_MIN; // 最大值初始化为最小整数
    int a2 = INT_MIN; // 次大值初始化为最小整数

    for (int i = 0; i < n; ++i) {
        int num;
        cin >> num; // 逐一读取每个正整数

        if (num > a1) {
            // 当前数字比最大值大,则更新最大值和次大值
            a2 = a1;
            a1 = num;
        } else if (num > a2) {
            // 当前数字介于最大值和次大值之间,更新次大值
            a2 = num;
        }
    }

    cout << a2 << endl; // 输出次大值
}

int main() {
    max2();
    return 0;
}

在这里插入图片描述


3. 核心逻辑逐步解析

在这里插入图片描述


定义并初始化变量

在这里插入图片描述

int a1 = INT_MIN;
int a2 = INT_MIN;
  • 目的
    • a1 用于记录当前的最大值。
    • a2 用于记录当前的次大值。
    • 初始化为 INT_MIN,以确保任何正整数输入都可以覆盖初始值。

遍历并处理输入数据

在这里插入图片描述

for (int i = 0; i < n; ++i) {
    int num;
    cin >> num;
  • 使用 for 循环逐一读取正整数,并对每个输入值进行处理。
  • 每次读取到的新数字需要根据与 a1a2 的关系进行条件判断。

更新最大值与次大值

在这里插入图片描述

if (num > a1) {
    a2 = a1;
    a1 = num;
} else if (num > a2) {
    a2 = num;
}
  • 逻辑分析
    1. num > a1 时:
      • 原最大值 a1 退化为次大值 a2
      • 新数字 num 成为新的最大值 a1
    2. num 位于最大值 a1 和次大值 a2 之间时:
      • 更新 a2 为当前数字 num

输出结果

在这里插入图片描述

cout << a2 << endl;
  • 循环结束后,a2 中存储的是次大值,直接输出。

4. 示例分析

在这里插入图片描述


示例输入

在这里插入图片描述

10
10 9 8 7 6 5 4 3 2 1

示例输出

在这里插入图片描述

9

数据处理过程

在这里插入图片描述

迭代次数当前数字 (num)最大值 (a1)次大值 (a2)
11010INT_MIN
29109
38109
101109

最终结果:次大值为 9。


💯高级拓展与优化分析

在这里插入图片描述


时间与空间复杂度

在这里插入图片描述

  • 时间复杂度
    • 对输入数据的单次遍历,复杂度为 O ( n ) O(n) O(n),与数据规模呈线性关系。
  • 空间复杂度
    • 仅使用两个额外变量 a1a2,复杂度为 O ( 1 ) O(1) O(1)

潜在错误与改进方向

在这里插入图片描述

  1. 初始化问题

    • 如果未正确初始化 a1a2,例如初始化为 0,在输入为负数时会导致错误。
    • 为避免此类问题,需始终选择合适的初始值,例如 INT_MIN
  2. 边界条件处理

    • 当 ( n = 2 ) 时,代码需要保证能够正确处理这类极小输入规模的场景。
  3. 逻辑健壮性

    • 对于更复杂的输入场景(如输入中存在重复值或非法值),需增加必要的输入校验逻辑。

数学与工程意义

在这里插入图片描述
从数学角度来看,本题的核心问题是动态维护“前两大值”。这类问题在实际工程中有广泛应用,例如:

  • 流式数据处理:实时更新数据流的统计特性。
  • 排名问题:动态维护某指标的前 k 个最大值。

在资源受限的场景下(如嵌入式设备或内存有限的系统),设计类似的轻量级算法尤为重要。


💯多种解法的对比与讨论

在这里插入图片描述

排序法

  • 思路:对输入数据排序,取倒数第二个值。
  • 时间复杂度 O ( n log ⁡ n ) O(n \log n) O(nlogn)
  • 缺点:额外的空间和时间开销。
    在这里插入图片描述

分治法

  • 思路:递归分组寻找最大值和次大值。
  • 时间复杂度:接近 O ( n ) O(n) O(n)
  • 缺点:代码复杂度较高,且在小规模数据上优势不明显。
    在这里插入图片描述

💯小结

  • 在这里插入图片描述
    通过本题,我们可以清晰认识到在有限资源条件下,如何设计高效算法以满足问题需求。这不仅考察了程序的正确性,还着重强调了代码的优化能力和设计美感。
    这种能力的培养需要长期的练习和理论积累,同时在不同场景中总结经验。更重要的是,这类问题的解决思路能够拓展到更广泛的工程实践中,例如实时数据分析、大规模流数据处理等领域,为构建更高效的系统打下坚实基础。

在这里插入图片描述


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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

修改git_bash命令行默认显示

1 背景 Git Bash默认显示用户名、主机、全路径&#xff0c;对于截图而言&#xff0c;会泄露一些隐私。 想办法去掉这些信息。 2 代码内容 # Shows Git branch name in prompt. parse_git_branch() {git branch 2> /dev/null | sed -e /^[^*]/d -e s/* \(.*\)/ (\1)/ } # …

Windwos Hyper-v 虚拟机SSH连接失败的问题

Windwos Hyper-v 虚拟机SSH连接失败的问题 一、问题现象&#xff1a; hyper-v里的虚拟机和宿主机都能正常访问外网&#xff0c;虚拟机也做了静态IP设置&#xff0c;但是宿主机就是无法通过SSH连接到虚拟机。 二、解决办法&#xff1a; 1、打开windows的高级网络设置&#x…

android studio创建虚拟机注意事项

emulator 启动模拟器的时候&#xff0c;可以用 AVD 界面&#xff0c;也可以用命令行启动&#xff0c;但命令行启 动的时候要注意&#xff0c;系统有两个 emulator.exe &#xff0c;建议使用 emulator 目录下的那个&#xff01;&#xff01; 创建类型为google APIs的虚拟机可从…

Spring Boot中实现JPA多数据源配置指南

本文还有配套的精品资源&#xff0c;点击获取 简介&#xff1a;本文详细介绍了在Spring Boot项目中配置和使用JPA进行多数据源管理的步骤。从引入依赖开始&#xff0c;到配置数据源、创建DataSource bean、定义实体和Repository&#xff0c;最后到配置事务管理器和使用多数据…

CSS学习记录04

CSS边框 CSS border 属性指定元素边框的样式、宽度和颜色。border-style 属性指定要显示的边框类型。dotted - 定义点线边框dashed - 定义虚线边框solid - 定义实线边框double - 定义双边框groove - 定义3D坡口边框&#xff0c;效果取决于border-color值ridge - 定义3D脊线边框…

【ArcGISPro】训练自己的深度学习模型并使用

本教程主要训练的是识别汽车的对象检测模型 所使用的工具如下(导出训练数据进行深度学习、训练深度学习模型、使用深度学习检测对象) 1.准备训练数据 1.1新建面矢量,构建检测对象 右键地理数据库->新建->要素类 选择面类型 1.2点击编辑窗口进行勾画汽车检测对象…

芝法酱学习笔记(1.3)——SpringBoot+mybatis plus+atomikos实现多数据源事务

一、前言 1.1 业务需求 之前我们在讲解注册和登录的时候&#xff0c;有一个重要的技术点忽略了过去。那就是多数据源的事务问题。 按照我们的业务需求&#xff0c;monitor服务可能涉及同时对监控中心数据库和企业中心数据库进行操作&#xff0c;而我们希望这样的操作在一个事…

Centos服务器如何访问windows的共享目录

CentOS服务器访问Windows的共享目录通常需要使用SMB/CIFS&#xff08;Server Message Block/Common Internet File System&#xff09;协议。以下是详细的步骤&#xff1a; 1、Windows端设置共享文件夹 1&#xff09;右键要共享的文件夹&#xff0c;点击属性-->在“共享”选…

JVM, JRE 和 JDK

JRE: Java Runtime Environment, Java 运行环境. JDK: Java Development Kit, Java 开发工具包. JRE JVM 核心类库 运行工具 JDK JVM 核心类库 开发工具 JVM: Java Virtual Machine, Java 虚拟机. 核心类库: Java 已经写好的东西, 直接拿来用即可. 开发工具: 包括 …

图数据库 | 13、图数据库架构设计——高性能计算架构再续

书接上文 图数据库 | 12、图数据库架构设计——高性能计算架构​​​​​​。昨天老夫就图数据库架构设计中的 实时图计算系统架构、图数据库模式与数据模型、核心引擎如何处理不同的数据类型、图计算引擎中的数据结构 这四块内容进行了展开讲解&#xff0c;今儿继续往下、往深…

Linux Cgroup学习笔记

文章目录 Cgroup(Control Group)引言简介Cgroup v1通用接口文件blkio子系统cpu子系统cpuacct子系统cpuset子系统devices子系统freezer子系统hugetlb子系统memory子系统net_cls子系统net_prio子系统perf_event子系统pids子系统misc子系统 Cgroup V2基础操作组织进程和线程popula…

R语言 | 峰峦图 / 山脊图

目的&#xff1a;为展示不同数据分布的差异。 1. ggplot2 实现 # 准备数据 datmtcars[, c("mpg", "cyl")] colnames(dat)c("value", "type") head(dat) # value type #Mazda RX4 21.0 6 #Mazda RX4 Wag …

java+ssm+mysql收纳培训网

项目介绍&#xff1a; 使用javassmmysql开发的收纳视频培训网&#xff0c;系统包含超级管理员&#xff0c;系统管理员、培训师、用户角色&#xff0c;功能如下&#xff1a; 超级管理员&#xff1a;管理员管理&#xff1b;用户管理&#xff08;培训师、用户&#xff09;&#…

【教程】创建NVIDIA Docker共享使用主机的GPU

转载请注明出处&#xff1a;小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你&#xff0c;欢迎[点赞、收藏、关注]哦~ 这套是我跑完整理的。直接上干货&#xff0c;复制粘贴即可&#xff01; # 先安装toolkit sudo apt-get update sudo apt-get install -y ca-certifica…

【全攻略】React Native与环信UIKit:Expo项目从创建到云打包完整指南

前言 在当今快速发展的移动应用领域&#xff0c;React Native 因其跨平台开发能力和高效的开发周期而受到开发者的青睐。而 Expo&#xff0c;作为一个基于 React Native 的框架&#xff0c;进一步简化了开发流程&#xff0c;提供了一套完整的工具链&#xff0c;使得开发者能够…

新浪财经-数据中心-基金重仓GU-多页数据批量获取

拉到底部&#xff0c;可以看到一共有6页。 import pandas as pd dfpd.DataFrame() url_strhttp://vip.stock.finance.sina.com.cn/q/go.php/vComStockHold/kind/jjzc/index.phtml?p for i in range(6): urlstr(url_str)str(i1) df pd.concat([df,pd.read_html(url)…

从爱尔兰歌曲到莎士比亚:LSTM文本生成模型的优化之旅

上一篇&#xff1a;《再用RNN神经网络架构设计生成式语言模型》 序言&#xff1a;本文探讨了如何通过多种方法改进模型的输出&#xff0c;包括扩展数据集、调整模型架构、优化训练数据的窗口设置&#xff0c;以及采用字符级编码。这些方法旨在提高生成文本的准确性和合理性&am…

ElasticSearch常见的索引_集群的备份与恢复方案

方案一&#xff1a;使用Elasticsearch的快照和恢复功能进行备份和恢复。该方案适用于集群整体备份与迁移&#xff0c;包括全量、增量备份和恢复。 方案二&#xff1a;通过reindex操作在集群内或跨集群同步数据。该方案适用于相同集群但不同索引层面的迁移&#xff0c;或者跨集…

软件工程复习记录

基本概念 软件工程三要素&#xff1a;方法、工具、过程 软件开发方法&#xff1a;软件开发所遵循的办法和步骤&#xff0c;以保证所得到的运行系统和支持的文档满足质量要求。 软件开发过程管理 软件生命周期&#xff1a;可行性研究、需求分析、概要设计、详细设计、编码、测…

快速了解 Aurora DSQL

上周在 AWS re:Invent大会&#xff08;类似于阿里云的云栖大会&#xff09;上推出了新的产品 Aurora DSQL[1] &#xff0c;在数据库层面提供了多区域、多点一致性写入的能力&#xff0c;兼容 PostgreSQL。并声称&#xff0c;在多语句跨区域的场景下&#xff0c;延迟只有Google …