题目 3334: 蓝桥杯2025年第十六届省赛真题-园艺

题目 3334: 蓝桥杯2025年第十六届省赛真题-园艺

时间限制: 2s 内存限制: 192MB 提交: 129 解决: 37

题目描述

小蓝从左到右种了 n 棵小树,第 i 棵树的高度为 hi ,相邻树的间隔相同。 小蓝想挪走一些树使得剩下的树等间隔分布,且从左到右高度逐渐上升(相邻 两棵树高度满足右边的比左边的高),小蓝想知道最多能留下多少棵树。

输入格式

输入的第一行包含一个正整数 n 。

第二行包含 n 个正整数 h1, h2, · · · , hn ,相邻整数之间使用一个空格分隔。

输出格式

输出一行包含一个整数表示答案。

样例输入复制

6

3 5 4 7 6 7

样例输出复制

3

提示

【样例说明】

留下第 1、3、5 棵树,它们等间隔且从左到右高度逐渐上升。

【评测用例规模与约定】

对于 30% 的评测用例,1 ≤ n ≤ 500 ;

对于 60% 的评测用例,1 ≤ n ≤ 3000 ;

对于所有评测用例,1 ≤ n ≤ 5000 ,0 < hi < 106 。

1.分析

遍历所有开始下标和间隔。

注意要实时更新数量,可能不连续。

2.代码

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<vector>
#include<cmath>
using namespace std;
const int MAX = 1e4 + 10;
typedef long long LL;
int n,a[MAX],re;
int main() {
    cin >> n;
    for (int i = 0; i < n; i++) {
        cin >> a[i];
    }
    for (int i = 0; i < n; i++) {
        for (int k = 0; k <= i; k++) {
            int num = 0, t = -1;
            for (int j = k; j < n; j += i + 1) {
                if (a[j] > t) {
                    t = a[j];
                    num++;
                    re = max(re, num);
                }
                else {
                    num = 1;
                    t = a[j];
                } 
            }
        }
    }
    cout << re << endl;
    return 0;
}
相关推荐
007php0077 小时前
Redis高级面试题解析:深入理解Redis的工作原理与优化策略
java·开发语言·redis·nginx·缓存·面试·职场和发展
程序员杰哥9 小时前
什么是Jmeter? Jmeter工作原理是什么?
自动化测试·软件测试·python·测试工具·jmeter·职场和发展·测试用例
·云扬·14 小时前
【Leetcode hot 100】101.对称二叉树
算法·leetcode·职场和发展
睡不醒的kun19 小时前
leetcode算法刷题的第三十二天
数据结构·c++·算法·leetcode·职场和发展·贪心算法·动态规划
汉克老师1 天前
第十四届蓝桥杯青少组C++选拔赛[2023.1.15]第二部分编程题(4 、移动石子)
c++·算法·蓝桥杯·蓝桥杯c++·c++蓝桥杯
boonya1 天前
Redisson原理与面试问题解析
面试·职场和发展·redission·分布式中间件框架
旭意1 天前
C++微基础蓝桥杯之旅9.9-9.12
c++·算法·蓝桥杯
东方芷兰2 天前
Leetcode 刷题记录 21 —— 技巧
java·算法·leetcode·职场和发展·github·idea
青鱼入云2 天前
【面试场景题】电商订单系统分库分表方案设计
大数据·面试·职场和发展
程序员三藏2 天前
2025最新的软件测试面试八股文(800+道题)
自动化测试·软件测试·python·功能测试·测试工具·面试·职场和发展