当前位置: 首页 > wzjs >正文

做qq阅读网站介绍seo顾问服务 乐云践新专家

做qq阅读网站介绍,seo顾问服务 乐云践新专家,南山老品牌网站建设,装修哪家好前言 除了 A 题,唯一一道一遍过的题。 题目大意 我们定义满足以下所有条件的一个长度为 N N N 的序列 A ( A 1 , A 2 , … , A N ) A(A_1,A_2,\dots,A_N) A(A1​,A2​,…,AN​) 为波浪序列: N ≥ 4 N\ge4 N≥4(其实满足后面就必须满足这…

前言

除了 A 题,唯一一道一遍过的题。

题目大意

我们定义满足以下所有条件的一个长度为 N N N 的序列 A = ( A 1 , A 2 , … , A N ) A=(A_1,A_2,\dots,A_N) A=(A1,A2,,AN)波浪序列

  • N ≥ 4 N\ge4 N4(其实满足后面就必须满足这个条件)。
  • A 1 ≤ A 2 A_1\le A_2 A1A2(小心不要忘了这个条件)。
  • 有且只有一个峰。
  • 有且只有一个谷。

现在有个长度为 N N N 的序列 P P P,求有多少个连续的子段是波浪序列。

思路

我们看一下条件——有且只有一个峰、一个谷。但是,整个序列里面会有许多峰、许多谷。然后,我们会从中选取一个峰、一个谷和一些其他类别的元素构成波浪序列。显然,我们要记下所有峰、所有谷的位置。默认按从小到大顺序记。

接下来,我们枚举选取子段的右端点,从第一个既包含峰又包含谷的位置开始,一直枚举到 N N N。考虑左端点可能的取值范围。前面通过从小到大的顺序暗示了这里的重要算法——二分。二分什么呢?左端点下边界?上边界?都可以。因为它是上下边界都与峰谷的位置有关,而确定上边界的峰一定“紧挨着”确定下边界的峰(指的是中间不会有别的峰),谷也是同理。式子自己想想吧!不会可以看代码。

代码

请点击 这里 查看 AC 记录。

#include <cstdio>
#include <iostream>
#include <algorithm>
using namespace std;int n, p[300010];
int c1, v1[300010]; // peak
int c2, v2[300010]; // valley
int s1[300010];
int s2[300010];int main()
{cin >> n;for (int i = 1; i <= n; i++)cin >> p[i];for (int i = 2; i < n; i++){s1[i] = s1[i - 1];if (p[i - 1] < p[i] && p[i] > p[i + 1])v1[++c1] = i, s1[i]++;s2[i] = s2[i - 1];if (p[i - 1] > p[i] && p[i] < p[i + 1])v2[++c2] = i, s2[i]++;}if (!c1 || !c2){cout << "0" << endl;return 0;}long long ans = 0;for (int i = max(v1[1], v2[1]) + 1; i <= n; i++){int p1 = lower_bound(v1 + 1, v1 + c1 + 1, i) - v1 - 1;int p2 = lower_bound(v2 + 1, v2 + c2 + 1, i) - v2 - 1;
//		if (p1 < 0 || p2 < 0) p1 = p2 = 0;
//		cout << i << " " << p1 << " " << p2 << ": " << endl;
//		cout << " - " << v1[p1] << " " << v2[p2] << endl;
//		cout << " - " << v1[p1 - 1] << " " << v2[p2 - 1] << endl;if (v1[p1] > v2[p2]) continue;int vmx = max(v1[p1 - 1], v2[p2 - 1]) - 1;int vmn = min(v1[p1], v2[p2]) - 1;vmx = max(vmx, 0);if (i - vmx < 4) continue;if (i - vmn + 1 < 4) vmn = i - 3;ans += vmn - vmx;
//		cout << i << " " << vmx << " " << vmn << endl;}cout << ans << endl;return 0;
}

总结

时间复杂度 O ( N ⋅ log ⁡ N ) O(N\cdot\log N) O(NlogN),二分很好用。

http://www.dtcms.com/wzjs/390677.html

相关文章:

  • 家庭网络如何做网站服务器竞价排名软件
  • 企业网站建设哪家公司好开一个免费网站
  • 牙科医院网站开发产品关键词的搜索渠道
  • 免费推广网站在线seo首页优化
  • 佛山网站建设拓客科技公司员工培训内容有哪些
  • 新闻类网站的设计seo排名app
  • 如何用腾讯云做网站淘宝店铺推广
  • 做网站现在要多少钱百度论坛
  • 网站建设行业解决方案二十条优化措施全文
  • wordpress 位置签到seo关键词优化指南
  • 做动画视频的网站网站做优化好还是推广好
  • 教育中介公司网站建设费用网站制作的要点和步骤详解
  • 优秀网站设计 pdf重庆网站制作公司
  • 重庆汉沙科技做网站怎么样360推广客服电话是多少
  • 音乐网站制作视频教学杭州seo营销公司
  • 尚义网站建设wl17581网络推广运营途径
  • 顺德龙江网站建设互联网销售怎么做
  • 电子商务网站建设与管理pdf下载国际十大市场营销公司
  • 建站63年来第一次闭站 北京站辟谣网络营销专业学校排名
  • 秦皇岛做网站的公司选汉狮网站关键词快速排名服务
  • 帝国cms做搜索网站如何查询关键词的搜索量
  • 做网站如何在百度快照上排名长沙优化官网服务
  • 网站关键字优化技巧网站建设品牌公司
  • 用帝国做网站好做吗seo投放是什么意思
  • java做网站合适吗网站广告制作
  • 东营科技官方网站怎么做一个自己的网页
  • 微网站是自己做可以不搜索引擎优化实训报告
  • 网站建设开发html百度网盘电脑版
  • 回龙观网站建设市场营销七大策略
  • 曲靖网站设计日本进口yamawa