G Greater and Greater

article/2025/9/23 1:27:02

G Greater and Greater

Description
Given a sequence A of size n{n}n and a sequence B of size m, determine the number of subintervals(called S) of size m in A satisfying ∀i∈{1,2,⋯,m},Si≥Bi​.
Input
The first line contains two integers n,m (1≤n≤150000,1≤m≤min{n,40000}).
The second line contains n integers A1,A2,⋯,An (1≤Ai≤109), denoting the sequence A.
The third line contains n{n}n integers B1,B2,⋯,Bn (1≤Bi≤109), denoting the sequence B.
Output
Only one line containing one integer, denoting the answer.
Samples
Input 复制
6 3
1 4 2 8 5 7
2 3 3
Output
2
Hint
The two subintervals are [2,8,5],[8,5,7].
Source
2020牛客-2


题意:给你一个序列A,让你从A中找出一个些子串S,让串S对应位置Si上的元素大于等于Bi,问一共可以找出多少个这种的序列

思路:这是个考二进制的好题,第一步的转换就不好想。
首先判断A序列中的每个元素是否比B中的元素大,比B中的元素大即为一,否者为0

例如:
A:1 4 2 8 5 7
B:2 3 3
B[1] = 2 : 0 1 1 1 1 1
B[2] = 3 : 0 1 0 1 1 1
B[3] = 3 : 0 1 0 1 1 1

这一步转换就很妙了,因为我们可以发现只要有一条斜线全为1,那么此子串就是一个答案,但是我们这样求复杂度为O(n*m),我们可以将序列A,B排序,将复杂度降为O(n),我们从排序后的第一个数字开始算,那么如果比最大数字(B[1])还要大,那一定也比B[1]小的数字大
在这里插入图片描述

从此图可以看出(A[3],A[4],A[5])和(A[4],A[5],A[6])这两个串即为所求;
最后我们将每个数的二进制进行移位,具体操作如下:
B[1] = 2 : 0 1 1 1 1 1 左移零位
B[2] = 3 : 1 0 1 1 1 0 左移一位
B[3] = 3 : 0 1 1 1 0 0 左移两位
然后我们每一列都与1做&运算,最后看有几个一即可;

bitset:

bitset<N> test,tep;//创建N位的二进制位,默认值为零
test.set();//将所有位都置为一
test.set(i);//将第i位置为一
test.count();//1的个数
test&tep;//test与tep按位与
test<<i;//test左移i位,右面补零

Code:

#include<bits/stdc++.h>
#define bug(x) cout<<#x<<" = "<<x<<endl;
using namespace std;
typedef long long ll;
const int N = 1e5 + 5e4 +10;
const int inf = 1e9;
bitset<N>ans,bs;
vector<pair<int,int> >a,b;
int n,m,p;
bool cmp(pair<int,int> x,pair<int,int> y) {return x.first > y.first;
}
int main() {cin>>n>>m;int x;for(int i=0; i<n; i++) {cin>>x;a.push_back({x,i});}for(int i=0; i<m; i++) {cin>>x;b.push_back({x,i});}sort(a.begin(),a.end(),cmp);sort(b.begin(),b.end(),cmp);ans.set();int j = 0;for(int i=0; i<m; i++) {while(j<n&&a[j].first>=b[i].first) {bs.set(a[j].second);j++;}
//		for(int k=0;k<n;k++) cout<<bs[k]<<" ";
//		putchar('\n');ans&=bs>>b[i].second;}printf("%d",ans.count());return 0;
}

http://chatgpt.dhexx.cn/article/PT21FSNt.shtml

相关文章

C++ greater/less 和建堆

文章目录 STL中的greater<>()和less<>()Heap定义堆排序构建堆堆排序 C的STL中堆的实现 STL中的greater<>()和less<>() 两个函数的头文件为 排序的时候&#xff0c;默认是从小到大&#xff1b;从大到小排序要使第三个参数为greater()。 建堆的时候&…

Greater and Greater

题目 传送门 题目大意 给定大小为n的序列A和大小为m的序列B&#xff0c;计算A中所有大小为m的子区间S&#xff0c;满足 分析 本题使用了一个special的STL&#xff1a;bitset 考虑bitset&#xff0c;对每个A求一个长为m的bitset Si&#xff0c;其中Si[j]1当且仅当Ai≥Bj。…

Error: Microsoft Visual C++ 14.0 or greater is required 解决方法

在Windows上安装某些Python依赖包时经常会遇到如下错误&#xff0c;其原因是&#xff1a;安装包&#xff08;此处是box2d-py&#xff09;没有找到Microsoft Visual C 14.0或更高版本的运行环境&#xff0c;所以无法正常启动。 error: subprocess-exited-with-error....Running…

什么是MVP模式?

MVP&#xff08;Model-View-Presenter&#xff09;是MVC模式的改良&#xff0c;由IBM的子公司Taligent提出。 和MVC的相同之处在于&#xff1a;Controller/Presenter负责业务逻辑&#xff0c;Model管理数据&#xff0c;View负责显示。 1.各部分之间的通信,都是双向的. View &l…

理解MVP设计模式

版权声明&#xff1a;转载请注明本文出自远古大钟的博客&#xff08;http://blog.csdn.net/duo2005duo&#xff09;&#xff0c;谢谢支持&#xff01; 目录(?)[] 转载请注明本文出自远古大钟的博客&#xff08;http://blog.csdn.net/duo2005duo&#xff09;&#xff0c;谢谢支…

iOS-MVP模式

前言 最近一段时间&#xff0c;公司刚做完一个MVP项目&#xff0c;我有一个习惯&#xff1a;在项目结项之后总结一下项目中新接触的问题。Google一下关键字“iOS MVP”&#xff0c;发现一些文章&#xff0c;最后是 这篇文章 带给我对MVP 的一些认识。MVP似乎有好多的变种&#…

Android:安卓学习笔记之MVP模式的简单理解和使用

Android MVP模式的简单理解和使用 MVP模式1、 为什么使用MVP模式&#xff1f;1.1、实例说明 2、一步步让你理解MVP2.1、MVP实现第一步&#xff0c; 将页面拆分为M/V/P三个模块2.2、 MVP实现第2步&#xff0c; 使用接口通信&#xff0c;进一步解耦2.2.1、MVP遵从的面向对象原则 …

MVP开发模式解析

前言 由于项目里同事用到MVP开发模式&#xff0c;我看了几篇关于 MVP 的文章&#xff0c;对其有了基本的了解之后&#xff0c;便照猫画虎进行了开发&#xff0c;之后便再也没接触过 MVP。 最近空闲读了些MVP的文章&#xff0c;受益匪浅&#xff0c;于是打算写一篇关于MVP开发…

MVP模式的优缺点

MVP模式是MVC的一个演化版本&#xff0c;全称是Model view Presenter。 MVP能够有效的降低View的复杂性&#xff0c;避免业务逻辑被塞进View中,使得View变成一个混乱的“大泥坑”。 MVP模式会解除View与Model的耦合&#xff0c;同时又带来了良好的可扩展性&#xff0c;可测试…

Android MVP开发模式 google 官方Mvp架构详解(转)

Google官方MVP Sample代码解读 关于Android程序的构架, 当前最流行的模式即为MVP模式, Google官方提供了Sample代码来展示这种模式的用法.Repo地址: android-architecture.本文为阅读官方sample代码的阅读笔记和分析. 官方Android Architecture Blueprints [beta]:Android在如…

MVP模式的相关知识

MVP 是从经典的模式MVC演变而来&#xff0c;它们的基本思想有相通的地方&#xff1a;Controller/Presenter负责逻辑的处理&#xff0c;Model提供数据&#xff0c;View负责显示。作为一种新的模式&#xff0c;MVP与MVC有着一个重大的区别&#xff1a;在MVP中View并不直接使用Mod…

【iOS】MVP模式

文章目录 什么是MVP模式&#xff1f;图解 从MVC到MVP苹果的MVC为何要从MVC到MVP?MVP MVP模式下的工程MVP模式的优缺点 什么是MVP模式&#xff1f; MVP模式是MVC模式的一个演化版本&#xff0c;MVP全称Model-View-Presenter。&#xff08;关于MVC模式可见这篇文章&#xff09; …

浅谈安卓中的MVP模式

端午放假&#xff0c;天气下雨&#xff0c;于是乎在家撸一下博客&#xff0c;本篇博客将为大家解析MVP模式在安卓中的应用。 本文将从以下几个方面对MVP模式进行讲解&#xff1a; 1. MVP简介 2. 为什么使用MVP模式 3. MVP模式实例 4. MVP中的内存泄露问题 1. MVP简介&…

Android MVP模式 入门

1.前言 近些年来&#xff0c;Android架构模式有很多&#xff0c;我们比较熟知的有MVC&#xff0c;MVP以及MVVM&#xff0c;目前Android市场中使用最多的应该是MVP架构&#xff0c;虽然MVVM结合DataBing看似更加方便&#xff0c;但在一般公司中使用的还是比较少。其实模式这种东…

MVP模式实例解释

为什么在UI层包含太多的逻辑是很糟糕的&#xff1f;在既不手动运行应用程序&#xff0c;也不维护丑陋的自动执行UI组件的UI运行者脚本(runner script)的情况下&#xff0c;位于应用程序UI层中的代码是非常难于调试的。虽然这本身就是一个很大的问题&#xff0c;一个更大的问题是…

Android开发之MVP模式

前言&#xff1a;在之前的开发中一直用的是mvc模式搭建的项目&#xff0c;所以我对于mvp也一直只是停留在理论和demo阶段上。正好现在的项目是被小伙伴借助dragger搭建的mvp模式的结构&#xff0c;所以就想着总结整理一下mvp模式的东西并写出来&#xff0c;也算是作为自己使用了…

MVP模式与MVC模式

源地址&#xff1a;http://www.cnblogs.com/cuihongyu3503319/archive/2009/01/09/1372820.html MVP模式与MVC模式(转) MVP 是从经典的模式MVC演变而来&#xff0c;它们的基本思想有相通的地方&#xff1a;Controller/Presenter负责逻辑的处理&#xff0c;Model提供数据&#x…

MVP模式从入门到精通

首先附上自己写的一个MVP的demo&#xff0c;这是一个很标准的MVP&#xff0c;Github地址如下&#xff1a; https://github.com/SilasGao/MVPDemo 首先MVP 是从经典的MVC架构演变而来&#xff0c;那我们是不是要先说下何为MVC模式&#xff1f; 系统C/S(Client/Server)三层架构模…

MVP模式使用示例详解

什么是MVP模式? 这个MVP可不是腾讯游戏《王者荣耀》中的MVP。我们今天要讨论的MVP其实同MVC一样&#xff0c;是一种编程模式和思想&#xff0c;也许更准确地讲是一种架构。 MVP和MVC的区别 提到MVP模式&#xff0c;大家自然避免不了要和我们以前常用的MVC模式进行对…

MVP设计模式

Model–view–presenter (MVP) 是model–view–controller (MVC)设计模式派生出来的。MVP经常用来创建用户界面。 presenter是作为一个“中间人”的角色存在。在MVP中&#xff0c;所有页面显示逻辑都会被推送到presenter。 以下这张图是MVC模式的&#xff1a; MVP与MVC有着一…