2023暑假牛客多校6- E.Sequence

news2025/1/12 17:59:38

题目描述

You have an array of n elements a_1,a_2,......a_n.

For each task, you have three integers l,n,k.

Ask whether you can find an arrayb of k - 1 integers satisfy:

  • l\leq b_1 < b2<b3 <\cdot \cdot \cdot <b_{k-1}<r
  • sum(l,b_1),sum(b_1+1,b_2),......,sum(b_{k-1}+1,r)are the multiplies of 2

Specially, if k=1, it should satisfy sum(l,r) is the multiply of 2

We define sum(l,r)=\sum_{i=l}^{r}a_i(l\leq r).

If possible, print "YES". Otherwise, print "NO".

输入描述

Each test contains multiple test cases. The first line contains the number of test cases T(1\leq T\leq 10000).
The description of the test cases follows.

The first line contains two integers n,q(1\leq n,q\leq 10^{5}).

The second line contains n� integers a_1,a_2,...a_n(1\leq a_i \leq 10^{10}).

Each of the next q lines contains three integersl,r,k(1\leq l\leq r \leq n,1\leq k \leq 10^5).

It's guaranteed that \sum n,\sum q \leq 5 \times 10^5

输出描述

For each test case, output "YES" or "NO".

样例

输入:

2
3 3
1 2 3
1 2 1
1 3 1
2 3 1
3 3
2 2 2
1 2 1
1 2 2
1 2 3

输出:

NO
YES
NO
YES
YES
NO

题目大意:

给定一个区间,将这个区间划分为 k 段,每一段的和都要求是偶数,判断给定的区间能不能成功求出划分

思路:

可以先求解一个前缀和,根据前缀和判断一下。因为 l-r 这个区间的和要求是偶数(包含这两个端点),如果求出前l-1个数的和为奇数,那么前 r 个数的和也必须为奇数;如果前l-1个数是偶数,那个前 r 个数的和必须为偶数。

 那么我们就可以知道,如果两个端点的前缀和是偶数,那个划分时间到x位置的前缀和也应该为偶数,如果两个端点的前缀和为奇数,那么到x位置的前缀和也应该为奇数。所以我们可以设置两个数据,分别来记录前缀和为奇数和前缀和为偶数的个数的前缀和。判断两边的端点是全奇还是全偶,求出区间最多可以划分为多少个,如果最多可以划分的个数小于需要划分的个数就是NO大于等于就是YES

代码:

#include<bits/stdc++.h>
using namespace std;

const int N = 1e5 +7;

using ll = long long;

ll a[N], kcnt[N], vis[N],kcnt1[N];

void solve() {
    vis[0] = 1;
    int n, q;
    cin >> n >> q;
    for(int i = 1; i <= n; i++) {
        cin >> a[i];
        kcnt[i] = 0;
        vis[i] = 0;
    }
    ll sum = 0;
    bool f = 0;
    for(int i = 1; i <= n; i++) {
        sum += a[i];
        if(sum % 2 == 0) {
            kcnt[i] = kcnt[i - 1] + 1;
            kcnt1[i] = kcnt1[i - 1];
            vis[i] = 1;
        }
        else {
            kcnt[i] = kcnt[i - 1];
            kcnt1[i] = kcnt1[i - 1] + 1;
            vis[i] = 0;
        }
    }
//    for(int i = 0; i <= n; i++) {
//        cout << kcnt[i] << ' ' << vis[i] << '\n';
//    }
    while(q--) {
        int l, r, k;
        cin >> l >> r >> k;
        if(k > r - l + 1) {
            cout << "NO\n";
            continue;
        }
        
        if(vis[r] ^ vis[l - 1]) {
            cout << "NO\n";
            continue;
        }

        ll tk = kcnt[r] - kcnt[l - 1];

        if(!vis[l - 1]){
            tk = kcnt1[r] - kcnt1[l - 1];
        }

        
        if(tk >= k) {
            cout << "YES\n";
        }
        else {
            cout << "NO\n";
        }
    }
}

int main() {
    ios::sync_with_stdio(0); cin.tie(0); cout.tie(0);
    int T = 1;
    cin >> T;
    while(T--) {
        solve();
    }

    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/844592.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java虚拟机怎样设置CLASSPATH的环境变量?

CLASSPATH环境变量用于保存一系列类包的路径&#xff0c;它和PATH环境变量的查看与配置方式完全相同。当Java虚拟机需要运行一个类时&#xff0c;会在CLASSPATH环境变量定义的路径下寻找所需的.class文件和类包。 为了让Java虚拟机能找到所需的class文件&#xff0c;就需要对C…

模拟实现消息队列项目(系列3) -- 服务器模块(硬盘管理)

目录 前言 1. 创建项目 2. 创建核心类 2.1 Exchange 2.2 MSQueue 2.3 Binding 2.4 Message 3. 数据库设计 3.1 SQLite 配置 3.2 Mapper层代码实现 3.2.1 创建表操作 3.2.2 交换机 队列 绑定的增加和删除 3.3 实现DataBaseManager 3.4 DataBaseManager单元测试 4.…

【JS】实现系统取色器

效果 使用环境说明 根据当前的信息&#xff0c;截至到 2023 年 8 月&#xff0c;以下是一些支持使用 new EyeDropper() 的主要浏览器&#xff08;可能还有其他浏览器也提供了类似的功能&#xff09;&#xff1a; Google Chrome&#xff1a;从 Chrome 94 版本开始引入了 new Ey…

Linux下共享windows 一键搞定

编写脚本 [rootlocalhost ~]# vim dd.sh#!/bin/bash yum -y install samba mkdir -p /home/shar sss dddecho " [share]comment Shared Folderpath /homebrowseable yeswritable yesguest ok yes " > /etc/samba/smb.confchmod x /home/* useradd qqqq s…

Qgis核密度分析

不建议使用Qgis进行核密度分析&#xff0c;建议使用arcgis&#xff0c;arcgis更简单。 arcgis核密度分析 Qgis核密度分析有两种&#xff1a; 法一:符号化&#xff0c;热图。 缺点&#xff1a;使用不方便&#xff0c;只适合看一下效果。 法二&#xff1a;工具栏搜索&#xff…

linux和C++中的 线程同步与线程安全 对比

线程同步与线程安全 线程进程与线程的区别并发和并行的区别linux线程常用接口函数函数定义函数使用 多线程理解 线程同步五个线程同时启动&#xff0c;每一个循环打印3次五个线程&#xff0c;每一个循环1000 结果是<5000代码和测试结果测试结果分析可以用信号量和互斥锁解决…

C语言标准定义的32个关键字

欢迎关注博主 Mindtechnist 或加入【智能科技社区】一起学习和分享Linux、C、C、Python、Matlab&#xff0c;机器人运动控制、多机器人协作&#xff0c;智能优化算法&#xff0c;滤波估计、多传感器信息融合&#xff0c;机器学习&#xff0c;人工智能等相关领域的知识和技术。 …

PyTorch搭建神经网络

PyTorch版本&#xff1a;1.12.1PyTorch官方文档PyTorch中文文档 PyTorch中搭建并训练一个神经网络分为以下几步&#xff1a; 定义神经网络定义损失函数以及优化器训练&#xff1a;反向传播、梯度下降 下面以LeNet-5为例&#xff0c;搭建一个卷积神经网络用于手写数字识别。 …

日志分析和流量分析

目录 [陇剑杯 2021]日志分析&#xff08;问1&#xff09; [陇剑杯 2021]日志分析&#xff08;问2&#xff09; [陇剑杯 2021]日志分析&#xff08;问3&#xff09; [陇剑杯 2021]简单日志分析&#xff08;问1&#xff09; [陇剑杯 2021]简单日志分析&#xff08;问3&#…

智慧水利整体解决方案[43页PPT]

导读&#xff1a;原文《智慧水利整体解决方案[43页PPT]》&#xff08;获取来源见文尾&#xff09;&#xff0c;本文精选其中精华及架构部分&#xff0c;逻辑清晰、内容完整&#xff0c;为快速形成售前方案提供参考。 完整版领取方式 完整版领取方式&#xff1a; 如需获取完整的…

docker小白第一天

docker小白第一天 docker是什么docker理念容器与虚拟机比较docker能干什么docker官网介绍docker的基本组成docker平台架构 docker是什么 系统平滑移植&#xff0c;容器虚拟化技术。即源代码配置环境版本&#xff0c;打个包形成一个镜像文件&#xff0c;即软件带环境一起安装&a…

企业接口测试流程总结,你都走了哪些弯路?背锅不存在的...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 首先我们要明确&a…

LeetCode 周赛上分之旅 # 37 多源 BFS 与连通性问题

⭐️ 本文已收录到 AndroidFamily&#xff0c;技术和职场问题&#xff0c;请关注公众号 [彭旭锐] 和 BaguTree Pro 知识星球提问。 学习数据结构与算法的关键在于掌握问题背后的算法思维框架&#xff0c;你的思考越抽象&#xff0c;它能覆盖的问题域就越广&#xff0c;理解难度…

ArcGIS制作带蒙版的遥感影像地图

这次文章我们来介绍一下&#xff0c;如何通过一个系统的步骤完成ArcGIS制作带蒙版的遥感影像地图。 主要的步骤包括&#xff1a; 1 添加行政区划数据 2 导出兴趣去乡镇矢量范围 3 添加遥感影像底图 4 制作蒙版 5 利用自动完成面制作蒙版 6 标注乡镇带晕渲文字 7 …

Golang 包详解以及go mod

Golang 中包的介绍和定义 包(package)是多个 Go 源码的集合,是一种高级的代码复用方案,Go 语言为我们提供了 很多内置包,如 fmt、strconv、strings、sort、errors、time、encoding/json、os、io 等。 Golang 中的包可以分为三种:1、系统内置包 2、自定义包 3、第三方包…

云服务器SVN仓库搭建(以阿里云为例)

远程连接阿里云服务器 安装svn(注意需要root权限使用命令sudo su) yum install subversion 安装成功后查看svn版本 svnserve --version 创建版本库的根目录 mkdir /var/svn 创建代码仓库 svnadmin create /var/svn/test 当前生成的目录结构 此处为svn的配置文件 创建用户名…

C# App.config和Web.config加密

步骤1&#xff1a;创建加密命令 使用ASP.NET提供的命令工具aspnet_regiis来创建加密命令。 1、打开控制台窗口&#xff0c;在命令行中输入以下命令&#xff1a; cd C:\Windows\Microsoft.NET\Framework\v4.xxxxx aspnet_regiis.exe -pef connectionStrings "C:\MyAppFo…

【PyQt5程序的打包和发布】

【PyQt5程序的打包和发布】 1 安装Pyinstaller模块2 打包普通Python程序3 打包PyQt5程序4 打包资源文件 1 安装Pyinstaller模块 pip install Pyinstaller2 打包普通Python程序 普通Python程序由Python内部库提供&#xff0c;不包含第三方库模板。 使用如下命令打包&#xff1…

【Docker】数据库动态授权组件在Kubernetes集群下的测试过程记录

目录 背景 组件原理 测试设计 环境 测试脚本 脚本build为linux可执行文件 镜像构建 Dockerfile Docker build 镜像有效性验证 总结 资料获取方法 背景 我们都知道出于安全性考虑&#xff0c;生产环境的权限一般都是要做最小化控制&#xff0c;尤其是数据库的操作授…

【现网】记一次并发冲突导致流量放大的生产问题

目录 事故现象 转账 业务背景介绍 背景一&#xff1a;转账流程 转账流程 转账异常处理 转账异常处理流程图 背景二&#xff1a;账户系统合并 实际全流程&#xff1a; 背景三&#xff1a;扣内存数据库逻辑 背景四&#xff1a;调用方重试逻辑 问题定位 总结 资料获取…