太阳黑子最大数量一直增加的最长连续年数

一、题目

1、输入描述

输入一个正整数N(0<N≤1000000),表示数据记录的年数第一行,第二行,输入N个用空格隔开的正整数(0<正整数<1e9),表示连续N年的太阳黑子最大数量

2、输出描述

输出一个非负整数,表示太阳黑子最大数量连续增加记录中的最长连续年数。

3、输入样例

8

23124849

4、输出样例

4

二、分析

咱们首先来分析这道题

今天这段注解可以说是保姆级的了

cpp 复制代码
#include <iostream>  
#include <vector>
1、这两行代码包含了iostreamvector这两个库。iostream库用于处理输入输出操作,而vector库用于处理动态数组。
cpp 复制代码
int main() {
2、这是主函数的开始。
cpp 复制代码
int N;  
    std::cin >> N;
3、声明一个整数变量N,并从标准输入读取一个值赋给它。这个值表示接下来要输入的记录数量。
cpp 复制代码
std::vector<int> records(N);  
    for (int i = 0; i < N; i++) {  
        std::cin >> records[i];  
    }
4、创建一个大小为N的整数向量records,并循环读取N个整数,将它们存储在records向量中。
cpp 复制代码
int maxIncreasingYears = 0;  
    int currentIncreasingYears = 1;
5、声明并初始化两个整数变量。maxIncreasingYears用于存储连续增长的最长年限,而currentIncreasingYears用于追踪当前连续的增长年限。
cpp 复制代码
for (int i = 1; i < N; i++) {  
        if (records[i] > records[i - 1]) {  
            currentIncreasingYears++;  
        } else {  
            if (currentIncreasingYears > maxIncreasingYears) {  
                maxIncreasingYears = currentIncreasingYears;  
            }  
            currentIncreasingYears = 1;  
        }  
    }
6、这个循环遍历records向量,从第二个元素开始(索引为1)。如果当前元素大于前一个元素,则currentIncreasingYears增加1。否则,如果currentIncreasingYears大于maxIncreasingYears,则更新maxIncreasingYears的值,并将currentIncreasingYears重置为1。
cpp 复制代码
if (currentIncreasingYears > maxIncreasingYears) {  
        maxIncreasingYears = currentIncreasingYears;  
    }
7、这个if语句检查在循环结束后currentIncreasingYears是否仍然是最大的。这确保了我们不会错过在输入序列的最后一段连续增长。
cpp 复制代码
std::cout << maxIncreasingYears << std::endl;
8、输出连续增长的最长年限。
cpp 复制代码
return 0;  
}
9、主函数结束,并返回0,表示程序成功执行。

三、总结

这段代码读取一个整数N,然后读取N个整数,并将它们存储在一个向量中。接着,它找出并输出这些整数中连续增长的最长年限。

四、整合代码

cpp 复制代码
//给定一系列连续N年的太阳黑子最大数量记录,找出其中最长的连续年份,使得太阳黑子最大数量连续增加。

#include <iostream>
#include <vector>

int main() {
    int N;
    std::cin >> N;

    std::vector<int> records(N);
    for (int i = 0; i < N; i++) {
        std::cin >> records[i];
    }

    int maxIncreasingYears = 0;
    int currentIncreasingYears = 1;

    for (int i = 1; i < N; i++) {
        if (records[i] > records[i - 1]) {
            currentIncreasingYears++;
        } else {
            if (currentIncreasingYears > maxIncreasingYears) {
                maxIncreasingYears = currentIncreasingYears;
            }
            currentIncreasingYears = 1;
        }
    }

    if (currentIncreasingYears > maxIncreasingYears) {
        maxIncreasingYears = currentIncreasingYears;
    }

    std::cout << maxIncreasingYears << std::endl;

    return 0;
}

感谢您观看,咱们下班列车再会

相关推荐
kkeeper~1 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
2401_868534781 小时前
论企业网络设计
数据结构
wabs6662 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_876964132 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
嗝o゚3 小时前
CANN GE 算子融合——融合算法与调度策略
算法·昇腾·cann·ge
小江的记录本3 小时前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
Ulyanov5 小时前
用声明式语法重新定义Python桌面UI:QML+PySide6现代开发入门(一)
开发语言·python·算法·ui·系统仿真·雷达电子对抗仿真
数据科学小丫5 小时前
特征工程处理
人工智能·算法·机器学习
z落落5 小时前
C#参数区别
java·算法·c#
c238566 小时前
vector(下)
数据结构·算法