Matrix PKU 2155

问题描述
给定N * N矩阵A,其元素为0或1.A [i,j]表示第i行和第j列中的数字。最初我们有A [i,j] = 0(1 <= i,j <= N)。 

我们可以通过以下方式更改矩阵。给定一个左上角为(x1,y1)且右下角为(x2,y2)的矩形,我们使用“not”操作更改矩形中的所有元素(如果是'0'则更改它变为'1'否则将其变为'0')。要维护矩阵的信息,系统会要求您编写程序以接收和执行两种指令。 

1. C x1 y1 x2 y2(1 <= x1 <= x2 <= n,1 <= y1 <= y2 <= n)通过使用左上角为(x1,y1)和更低的矩形来改变矩阵 - 右角是(x2,y2)。 
2. Q xy(1 <= x, 
输入
输入的第一行是整数X(X <= 10),表示测试用例的数量。以下X块表示测试用例。<br> <br>每个块的第一行包含两个数字N和T(2 <= N <= 1000,1 <= T <= 50000),表示矩阵的大小和指令的数量。以下T行各自表示具有格式“Q x y”或“C x1 y1 x2 y2”的指令,其已在上面描述。点击
产量
对于每个查询输出一行,其具有表示A [x,y]的整数。<br> <br>每两个连续测试用例之间有一个空行。点击
样本输入
12 10C 2 1 2 2问2 2C 2 1 2 1问1 1C 1 1 2 1C 1 2 1 2C 1 1 2 2问1 1C 1 1 2 1问题2 1
样本输出
1001
采用树状数组的区域修改单点查询
注意一下细节   sum是自上而下  大于0    update是自下而上 小于等于N的!
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int N;
int c[1005][1005];int lowbit(int i)
{return i&-i;
}
void update(int x,int y,int v)
{for(int i=x;i<=N;i+=lowbit(i))for(int j=y;j<=N;j+=lowbit(j))c[i][j]+=v;
}
int sum(int x,int y)
{int ans=0;for(int i=x;i>0;i-=lowbit(i))for(int j=y;j>0;j-=lowbit(j))ans+=c[i][j];return ans;
}
int main()
{int cas,q;scanf("%d",&cas);int first=1;for(int i=1;i<=cas;i++){if(i!=1)printf("\n");scanf("%d%d",&N,&q);memset(c,0,sizeof(c));char s[5];int x1,x2,y1,y2;while(q--){scanf("%s",s);if(s[0]=='C'){scanf("%d%d%d%d",&x1,&y1,&x2,&y2);update(x1,y1,1);update(x2+1,y1,-1);update(x1,y2+1,-1);update(x2+1,y2+1,1);}else if(s[0]=='Q'){scanf("%d%d",&x1,&y1);printf("%d\n",sum(x1,y1)%2);}}}return 0;
}

 

转载于:https://www.cnblogs.com/bxd123/p/10358455.html

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

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

相关文章

Asp.Net微信发布菜单,出现“invalid sub button url domain hint”错误

在微信后台建立好微信菜单后&#xff0c;调用发布接口进行发布操作时&#xff0c;出现了下面的问题&#xff1a; invalid sub button url domain hint [V85WIa0180vr23] 解决办法&#xff1a; 进入微信公众平台&#xff0c;选择菜单“公众号设置”-》“功能设置”-》“JS接口…

[vue] 说说你对proxy的理解

[vue] 说说你对proxy的理解 vue的数据劫持有两个缺点: 1、无法监听通过索引修改数组的值的变化 2、无法监听object也就是对象的值的变化 所以vue2.x中才会有$set属性的存在proxy是es6中推出的新api&#xff0c;可以弥补以上两个缺点&#xff0c;所以vue3.x版本用proxy替换obje…

Linux小知识(零散)

terminal的起始是用户名主机名&#xff0c;后面是当前工作路径&#xff0c;紧跟着美元符号 $&#xff0c;代表shell提示符。 如果提示符显示的是“#”而不是“$"&#xff0c;则代表该terminal具有超级用户权限。 Gnome 和 KDE 是“桌面系统”&#xff0c;一种很多程序和函…

spring字符串判空_如何判断字符串为空

java中有多种判断String对象思否为空的方法,本文来梳理一下.java原生方法在java原生的语法中,String对象有一个API是isEmpty(),该方法会判断String对象是否为空,这里的isEmpty()完全等同于String.length()0,但是如果这是你的String对象是null呢?--String.isEmpty()就会报空指针…

[vue] 写出你知道的表单修饰符和事件修饰符

[vue] 写出你知道的表单修饰符和事件修饰符 事件修饰符.stop .prevent .capture .self .once .passive 表单修饰符.number .lazy .trim个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣…

通过Nginx配置多域名访问

通过Nginx配置多域名访问 一、下载Nginx 访问Nginx官网选择对应版本和安装包&#xff1a;http://nginx.org/ 以下讲述为在Windows环境下配置Nginx进行多域名访问 二、Nginx常用命令 1. 启动Nginx命令 解压缩Nginx包到指定目录&#xff0c;并打开命令行工具&#xff0c;切换…

[vue] vue项目有做过单元测试吗?

[vue] vue项目有做过单元测试吗&#xff1f;# 个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面试题

python json dict对象使用_Python中:dict(或对象)与json之间的互相转化

在Python语言中&#xff0c;json数据与dict字典以及对象之间的转化&#xff0c;是必不可少的操做。python在Python中自带json库。经过import json导入。json在json模块有2个方法&#xff0c;学习loads()&#xff1a;将json数据转化成dict数据dumps()&#xff1a;将dict数据转化…

java 资深工程师必备技能

开头语&#xff1a;do less, think more. 这句话说的不是让你只会纸上谈兵&#xff0c;而是做事有一套自己的标准&#xff0c;按项目需求划分不同的阶段进行按部就班按时按质按量的完成项目中的各种任务。 1. 具备一定项目管理的能力 对需求方提出的需求进行整理和归纳&#x…

bootstrap综合大作业_齐齐哈尔市克东县城市管理综合执法局昼夜奋战清冰雪,全力以赴保畅通...

近日&#xff0c;克东县再次迎来降雪&#xff0c;此次降雪时间长、密度大&#xff0c;为保证城区内交通顺畅及人员车辆出行安全&#xff0c;克东县城市管理综合执法局组织城管大队和环卫站科学统筹、迅速行动&#xff0c;全力以赴投入到清冰雪工作中。11月17日晚十点&#xff0…

[vue] 有使用过vue吗?说说你对vue的理解

[vue] 有使用过vue吗&#xff1f;说说你对vue的理解 1.mvvm框架 2.数据驱动 3.SPA 4.渐进式个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面试题

洛谷4951 地震 bzoj1816扑克牌 洛谷3199最小圈 / 01分数规划

洛谷4951 地震 1 #include<iostream>2 #include<cstdio>3 #include<algorithm>4 #define go(i,a,b) for(register int ia;i<b;i)5 #define ll long long6 #define db long double7 #define M 100018 #define N 4019 #define inf 1e15 10 #define eps 1e-…

[vue] 说说vue的优缺点

[vue] 说说vue的优缺点 这个感觉和对vue的理解是差不多的题 优点&#xff1a;1. 数据驱动 2.模块化 3.轻量级 4.SPA 5. 版本3.0的界面化管理工具比较好使 6.vue易入门 缺点&#xff1a;1. 不支持低版本浏览器个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃…

jsx怎么往js里传参数_Angular、React 当前,Vue.js 优劣几何?

在过去一年里&#xff0c;前端开发发展迅速&#xff0c;前端工程师的薪资亦是水涨船高。2019 更是热度不减&#xff0c;而作为近年来尤为热门的前端框架&#xff0c;Vue.js 自是积累了大量关注。那么&#xff0c;Vue.js 是适合你的框架吗&#xff1f;以下为译文&#xff1a;对于…

Concurrent HTTP connections in Node.js

原文&#xff1a; https://fullstack-developer.academy/concurrent-http-connections-in-node-js/ ------------------------------------------------------------------------------------------ Browsers, as well as Node.js, have limitations on concurrent HTTP connec…

形状相似的物品_空运一般货物及危险品和特殊物品对包装的要求和规定!

一.空运包装的基本作用1.包装的基本作用有三种&#xff1a;保护、保存和介绍。包装应在贮存期间和从制造厂运至消费中心期间&#xff0c;起到保护和保存内部货物的作用。保护货物不仅包括防止丢失、损坏和被盗&#xff0c;还包括根据货物的性质&#xff0c;防止货物受潮、失火、…

[vue] vue和react有什么不同?使用场景分别是什么?

[vue] vue和react有什么不同&#xff1f;使用场景分别是什么&#xff1f; 1、vue是完整一套由官方维护的框架&#xff0c;核心库主要有由尤雨溪大神独自维护&#xff0c;而react是不要脸的书维护&#xff08;很多库由社区维护&#xff09;&#xff0c;曾经一段时间很多人质疑vu…

coreldraw x4怎么会蓝屏_CorelDRAW广告条幅批量制作插件

由VBA探秘站长个人开发的一款条幅插件&#xff0c;用于广告行业快速制作条幅的好帮手。 所有用户可以在这个开源的版本基础上二次开发完善。界面截图软件架构基于VBA语言开发&#xff0c;插件形式为GMS。安装教程如果是非开发者用户&#xff0c;想直接使用插件&#xff0c;请直…

Python中数字之间的进制转换

https://www.cnblogs.com/Kingfan1993/p/9795541.html 在python中可以通过内置方法进行相应的进制转换&#xff0c;但需记得转化成非十进制时&#xff0c;都会将数字转化成字符串 转化成二进制 a 10 #声明数字&#xff0c;默认十进制 b bin(a) print(b , type(b)) 运行结果&…

[vue] 什么是双向绑定?原理是什么?

[vue] 什么是双向绑定&#xff1f;原理是什么&#xff1f; 双向数据绑定个人理解就是存在data→view,view→data两条数据流的模式。其实可以简单的理解为change和bind的结合。目前双向数据绑定都是基于Object.defineProperty()重新定义get和set方法实现的。修改触发set方法赋值…