news 2026/4/16 11:13:36

区间取反与区间数一【牛客tracker 每日一题】

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
区间取反与区间数一【牛客tracker 每日一题】

区间取反与区间数一

时间限制:2秒 空间限制:256M

网页链接

牛客tracker

牛客tracker & 每日一题,完成每日打卡,即可获得牛币。获得相应数量的牛币,能在【牛币兑换中心】,换取相应奖品!助力每日有题做,丰盈牛币日益多!

题目描述

对于给定的长度为n nn01 0101s ss(下标范围为[ 1 , n ] [1,n][1,n]),你需要构建一个能够动态维护区间和信息的数据结构,使得其能支持:

  1. 区间取反:将[ l , r ] [l,r][l,r]这个区间中的全部元素进行取反操作,即∀ i ∈ [ l , r ] , s i → 1 − s i ∀i∈[l,r],s_i→1−s_ii[l,r],si1si
  2. 区间数一:输出下标在[ l , r ] [l,r][l,r]这个区间中的所有元素值为1 11的元素的个数,即∑ i = l r 1 ( a i = 1 ) ∑_{i=l}^r1_{(a_i=1)}i=lr1(ai=1)

输入描述:

第一行输入两个整数n , q ( 1 ≦ n , q ≦ 5 × 10 5 ) n,q(1≦n,q≦5×10^5)n,q(1n,q5×105)代表01 0101s ss的长度、操作次数。
第二行输入一个长度为n nn01 0101s ( s i ∈ s(s_i∈s(si{0 , 1 0,10,1}) ))
此后q qq行,每行先输入一个整数o p ( 1 ≦ o p ≦ 2 ) op(1≦op≦2)op(1op2)代表操作编号,随后:

输出描述:

对于每一次询问,输出一行一个整数代表区间数一的结果值。保证至少存在一次询问。

示例1

输入:

6 4 100101 1 1 4 2 1 6 1 4 6 2 1 6

输出:

3

解题思路

采用位运算分块策略维护01 0101串,将长度为n nn01 0101串按每64 6464位划分为一个块,用无符号长整型数组b s bsbs存储(1 11对应位设为1 , 0 1,0100 00)。处理区间取反(o p = 1 op=1op=1)时,先对[ l , r ) [l,r)[l,r)范围内的完整块整体按位取反(异或− 1 -11),再分别对左右边界的不完整块,通过异或(1 u l l < < 1ull<<1ull<<(位偏移))− 1 -11取反边界内的位;处理区间统计1 11的个数(o p = 2 op=2op=2)时,先计算右边界块前r位的1 11的数量,减去左边界块前l ll位的1 11的数量,再累加中间完整块的1 11的总数(借助KaTeX parse error: Expected group after '_' at position 1: _̲_builtin_popcou…快速统计每块1 11的个数)。该方法将每次操作的时间复杂度降至O ( n / 64 ) O(n/64)O(n/64),适配n nnq qq5 e 5 5e55e5的规模,高效完成区间取反与1 11的个数统计操作。

代码内容

#include<bits/stdc++.h>usingnamespacestd;typedeflonglongll;typedefunsignedlonglongull;typedefpair<ll,ll>pii;constll p=1e9+7;constll N=2e5+10;ull bs[7813];intmain(){ll n,q;string s;cin>>n>>q>>s;for(ll i=0;i<n;i++){if(s[i]=='1')bs[i>>6]|=1ull<<(i&63);}ll op,l,r,lb,rb;while(q--){cin>>op>>l>>r;l--;lb=l>>6,rb=r>>6;if(op==1){for(ll i=lb;i<rb;i++)bs[i]^=-1;bs[lb]^=(1ull<<(l&63))-1;bs[rb]^=(1ull<<(r&63))-1;continue;}ll res=__builtin_popcountll(bs[rb]&(1ull<<(r&63))-1)-__builtin_popcountll(bs[lb]&(1ull<<(l&63))-1);for(ll i=lb;i<rb;i++)res+=__builtin_popcountll(bs[i]);cout<<res<<endl;}return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 22:30:12

【开题答辩全过程】以 高校失物招领信息管理系统的设计与开发为例,包含答辩的问题和答案

个人简介一名14年经验的资深毕设内行人&#xff0c;语言擅长Java、php、微信小程序、Python、Golang、安卓Android等开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。感谢大家的…

作者头像 李华
网站建设 2026/4/10 17:20:47

AI生成内容版权探索:Z-Image-Turbo云端环境下的水印集成

AI生成内容版权探索&#xff1a;Z-Image-Turbo云端环境下的水印集成 随着AI生成图像的普及&#xff0c;如何有效标识版权成为内容平台亟需解决的问题。Z-Image-Turbo作为新一代开源图像生成模型&#xff0c;凭借亚秒级生成速度和出色的中文理解能力&#xff0c;正被广泛应用于…

作者头像 李华
网站建设 2026/4/16 11:03:31

基于51单片机智能睡眠监测系统心率血氧呼吸频率检测设计DIY22-111

本设计由STC89C52单片机电路LCD1602液晶显示电路MAX32102心率血氧传感器电路麦克风声音呼吸频率检测电路蜂鸣器报警电路电源电路组成。1、LCD1602液晶实时显示心率、血氧和呼吸频率。2、如果心率超过120&#xff0c;则蜂鸣器报警&#xff0c;否则蜂鸣器不报警。3、当呼吸频率在…

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

10分钟玩转Z-Image-Turbo:零基础搭建你的AI艺术工作室

10分钟玩转Z-Image-Turbo&#xff1a;零基础搭建你的AI艺术工作室 作为一名平面设计师&#xff0c;你是否经常为寻找创意灵感而苦恼&#xff1f;Z-Image-Turbo作为一款开源的AI图像生成模型&#xff0c;能够帮助你快速生成高质量的设计素材。它采用创新的8步蒸馏技术&#xff0…

作者头像 李华
网站建设 2026/4/14 14:18:19

教学实践:如何在计算机课程中快速部署Z-Image-Turbo实验环境

教学实践&#xff1a;如何在计算机课程中快速部署Z-Image-Turbo实验环境 为什么选择Z-Image-Turbo作为教学工具 作为一名计算机教授&#xff0c;我最近在机器学习课程中遇到了一个难题&#xff1a;如何让数十名学生快速体验AI图像生成技术&#xff0c;而不必花费大量时间配置复…

作者头像 李华