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

c++开关灯

题目描述

现有 𝑛n 盏灯排成一排,从左到右依次编号为:11,22,……,𝑛n。然后依次执行 𝑚m 项操作。

操作分为两种:

  1. 指定一个区间 [𝑎,𝑏][a,b],然后改变编号在这个区间内的灯的状态(把开着的灯关上,关着的灯打开);
  2. 指定一个区间 [𝑎,𝑏][a,b],要求你输出这个区间内有多少盏灯是打开的。

灯在初始时都是关着的。

输入

第一行有两个整数 𝑛n 和 𝑚m,分别表示灯的数目和操作的数目。

接下来有 𝑚m 行,每行有三个整数,依次为:𝑐c、𝑎a、𝑏b。其中 𝑐c 表示操作的种类。

  • 当 𝑐c 的值为 00 时,表示是第一种操作。
  • 当 𝑐c 的值为 11 时,表示是第二种操作。

𝑎a 和 𝑏b 则分别表示了操作区间的左右边界。

输出

每当遇到第二种操作时,输出一行,包含一个整数,表示此时在查询的区间中打开的灯的数目。

样例输入 复制
4 5
0 1 2
0 2 4
1 2 3
0 2 4
1 1 4
样例输出 复制
1
2
提示

对于全部的测试点,保证 2≤𝑛≤1052≤n≤104,1≤𝑚≤1051≤m≤104,1≤𝑎,𝑏≤𝑛1≤a,b≤n,𝑐∈{0,1}c∈{0,1}。

#include<bits/stdc++.h>
using namespace std;
int a[10001],b[100001];
bool q[10001]={0},q1[10000]={0};
int n,m;
int main(){
	cin>>n>>m;
	for(int i=1;i<=m;i++){
		cin>>q[i]>>a[i]>>b[i];
		if(q[i]==0){
			for(int j=a[i];j<=b[i];j++){
				if(q1[j]==0) q1[j]=1;
				else q1[j]=0;		
			}
		}
		int ans=0;
		if(q[i]==1){
			for(int j=a[i];j<=b[i];j++){
				if(q1[j]==1) ans++;
			}
			cout<<ans<<endl;
		}
	}
	return 0;
}

 


http://www.kler.cn/a/297415.html

相关文章:

  • httpclient支持socks5和http代理调用接口
  • Spring AOP(面向切面编程)ProceedingJoinPoint 常用方法
  • Git的工作原理
  • 【生日视频制作】海上绿色摩托艇汽车艇车身AE模板修改文字软件生成器教程特效素材【AE模板】
  • 大二上学期计划安排
  • Web入门-09.Tomcat-入门程序解析
  • 前向渲染路径
  • 西门子PCS 7 如何根据用户需求定义导航区按钮
  • 自定义v-model的两种形式
  • MySQL数据备份的存储管理:策略、实践与自动化
  • aliyun图片存储OSS工具类
  • 2-89 基于matlab的图像去噪方法
  • 详解Spring中的单例模式
  • OpenFeign 使用案例教程
  • 代码随想录打卡Day27
  • 【Oracle篇】全面理解优化器和SQL语句的解析步骤(含执行计划的详细分析和四种查看方式)(第二篇,总共七篇)
  • [数据集][目标检测]电动车入梯进电梯电单车入梯检测数据集VOC+YOLO格式7106张3类别
  • (六十八)第 10 章 内部排序(简单选择排序)
  • zookeeper是啥?在kafka中有什么作用
  • 暂停Windows更新方法