news 2026/7/4 15:53:30

UVa 12788 Smooth Factor

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
UVa 12788 Smooth Factor

题目描述

给定一个整数数组a1,a2,…,ana_1, a_2, \ldots, a_na1,a2,,an,定义其平滑因子为:最长的连续子数组ap,…,aqa_p, \ldots, a_qap,,aq的长度,其中至多存在一个位置iiip<i≤qp < i \leq qp<iq)满足ai−1>aia_{i-1} > a_iai1>ai。换句话说,该子数组要么是完全非递减的,要么只包含一次“下降”。

要求对于多个测试用例,分别输出每个数组的平滑因子。

输入格式

  • 多个测试用例,每个用例两行。
  • 第一行:整数nnn1≤n≤1051 \leq n \leq 10^51n105)。
  • 第二行:nnn个整数a1,…,ana_1, \ldots, a_na1,,an0≤∣ai∣<1080 \leq |a_i| < 10^80ai<108)。

输出格式

  • 每个测试用例一行,输出对应数组的平滑因子。

样例输入

3 1 2 3 1 0 8 1 2 1 2 1 2 3 1 4 1 -10 -100 -100

样例输出

3 1 5 3

题目分析

本题要求寻找满足“至多包含一次下降”的最长连续子数组的长度。这里的“下降”指的是ai−1>aia_{i-1} > a_iai1>ai。换句话说,在子数组中,最多只能有一个位置使得前一个元素大于后一个元素。

关键点

  1. 连续性:子数组必须是原数组的连续一段。
  2. 至多一次下降:允许000次或111次下降。
  3. 高效计算nnn最大可达10510^5105,需要O(n)O(n)O(n)O(nlog⁡n)O(n \log n)O(nlogn)的算法。

思路推导

我们可以将问题转化为一个滑动窗口问题:

  • 维护一个窗口[left,right][left, right][left,right]
  • 用计数器dropCountdropCountdropCount记录窗口内下降的次数。
  • dropCount≤1dropCount \leq 1dropCount1时,窗口有效,可以扩展右边界。
  • dropCount>1dropCount > 1dropCount>1时,窗口无效,需要移动左边界直到dropCount≤1dropCount \leq 1dropCount1
  • 在移动左边界时,如果移出的位置原本是一个下降点,则dropCountdropCountdropCount需要减111
  • 每次窗口有效时,用当前窗口长度更新答案。

这样,我们通过一次遍历就能找到最长满足条件的子数组。


算法步骤

  1. 初始化left=0left = 0left=0maxLen=1maxLen = 1maxLen=1(至少长度为111),dropCount=0dropCount = 0dropCount=0
  2. 遍历右边界rightrightright111n−1n-1n1
    • 判断a[right−1]>a[right]a[right-1] > a[right]a[right1]>a[right]?如果是,则dropCountdropCountdropCount111
    • dropCount>1dropCount > 1dropCount>1时:
      • a[left]>a[left+1]a[left] > a[left+1]a[left]>a[left+1],则dropCountdropCountdropCount111
      • leftleftleft111
    • 计算当前窗口长度right−left+1right - left + 1rightleft+1,更新maxLenmaxLenmaxLen
  3. 输出maxLenmaxLenmaxLen

时间复杂度O(n)O(n)O(n),每个元素至多被访问两次。
空间复杂度O(1)O(1)O(1)(不计输入数组)。


代码实现

// Smooth Factor// UVa ID: 12788// Verdict: Accepted// Submission Date: 2025-12-15// UVa Run Time: 0.010s//// 版权所有(C)2025,邱秋。metaphysis # yeah dot net#include<bits/stdc++.h>usingnamespacestd;intmain(){ios::sync_with_stdio(false);cin.tie(nullptr);intn;while(cin>>n){vector<int>a(n);for(inti=0;i<n;++i)cin>>a[i];intleft=0,maxLen=1;// 至少长度为1intdropCount=0;// 窗口中下降的次数for(intright=1;right<n;++right){// 判断 right 是否为下降点if(a[right-1]>a[right])dropCount++;// 如果下降次数超过1,移动左边界直到满足条件while(dropCount>1){// 如果 left 是下降点,移出窗口时减少计数if(a[left]>a[left+1])dropCount--;left++;}// 更新最大长度maxLen=max(maxLen,right-left+1);}cout<<maxLen<<"\n";}return0;}

示例分析

以样例1 2 1 2 1 2 3 1为例:

  • 最长满足条件的子数组为1 2 1 2 3,长度为555
  • 其中只有一次下降(2>12 > 12>1),其余位置均非递减。

算法过程:

  • 窗口滑动过程中,当遇到第二次下降时(例如3>13 > 13>1),左边界移动,直到窗口中只保留一次下降,从而找到最长窗口。

总结

本题通过滑动窗口维护一个至多包含一次下降的连续子数组,在O(n)O(n)O(n)时间内求解。关键在于用dropCountdropCountdropCount记录下降次数,并通过移动左边界保持条件成立。代码简洁高效,适用于大数据范围。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/28 21:06:07

UVa 11617 An Odd Love

题目描述 春天到了&#xff0c;我们的朋友佩皮托&#xff08;Pepito\texttt{Pepito}Pepito&#xff09; 坠入了爱河。但他不确定她是否也爱他&#xff0c;于是他决定询问雏菊。他摘下一朵雏菊&#xff0c;交替说着“她爱我”和“她不爱我”&#xff0c;每说一句话就摘下一片花…

作者头像 李华
网站建设 2026/6/26 1:28:52

LobeChat能否对接Slack?团队协作平台集成方案

LobeChat 与 Slack 集成&#xff1a;构建团队智能协作中枢 在现代企业中&#xff0c;沟通工具早已不只是“聊天软件”——它们是信息流转的核心枢纽。Slack 每天承载着成千上万条项目讨论、任务分配和决策记录&#xff0c;而这些数据如果能被 AI 实时理解并参与其中&#xff0c…

作者头像 李华
网站建设 2026/7/4 22:46:37

集团宽带是什么意思?企业如何选择合适的宽带方案?

在当今这个信息爆炸的时代&#xff0c;企业对于网络的需求日益增长。而提到“集团宽带”&#xff0c;不少企业管理者或许会感到困惑&#xff1a;这到底是个什么概念?简单来说&#xff0c;集团宽带是指为满足大型企业或集团内部多个办公地点之间高效互联需求而设计的一种宽带服…

作者头像 李华
网站建设 2026/7/4 18:24:44

运维外包的公司靠谱吗?企业真能省心?

你有没有经历过这样的早晨&#xff1a;全员刚开工&#xff0c;邮件系统突然卡死&#xff0c;视频会议连不上&#xff0c;前台智能屏黑着&#xff0c;IT小哥满头大汗却查不出根源?这时候&#xff0c;一个念头冒出来&#xff1a;要不要把运维外包出去?这不是个别现象。如今写字…

作者头像 李华
网站建设 2026/7/4 11:29:29

HunyuanVideo-Foley:AI让视频自动配声

HunyuanVideo-Foley&#xff1a;AI让视频自动配声 你有没有试过剪完一段精心拍摄的日常vlog&#xff0c;回放时却像在看默片&#xff1f;——人影走动、锅铲翻飞&#xff0c;画面热火朝天&#xff0c;耳朵却一片死寂。观众还没来得及沉浸&#xff0c;就被这“无声胜有声”的尴尬…

作者头像 李华
网站建设 2026/7/4 10:44:25

信息安全技术与Kali Linux

信息安全技术概述 信息安全技术旨在保护信息系统中的数据免受未经授权的访问、泄露、篡改或破坏。其核心目标是确保数据的机密性、完整性和可用性&#xff08;CIA三要素&#xff09;。随着数字化进程加速&#xff0c;信息安全技术已成为企业、政府及个人的关键需求。 核心信息…

作者头像 李华