2020牛客寒假算法基础集训营6 F 十字阵列

https://ac.nowcoder.com/acm/contest/3007/F
题目描述

小 Q 新学会了一种魔法,可以对一个 N行M列 的网格上的敌人造成伤害

第 i 次使用魔法可以对网格上的一个十字形区域(即第 xi 行和第 yi 列的并)中的每个格子上的敌人造成 zi 点伤害

现在小 Q 一共使用了 H 次魔法,你需要在所有的施法完成之后统计造成伤害的情况,详见输出描述

提醒:本题输入规模较大,请使用高效的输入方式

1≤H≤500,000 1≤xi,yi,zi,N,M≤2000 1≤xi≤N,1≤yi≤M

思路 

 首先,对于每一个坐标(x_{i},y_{i}),它所在的行列都会受影响,那么对于某一个点(a,b)而言,最后的结果是他所在的行收到的总的影响+所在列收到的总影响,注意,如果中间有一次影响是因这个点而生,会多计算一次,所以用w[i][j]记录每个点受到的影响,用两个树状数组分别维护行和列,当收到(x_{i},y_{i})的影响后,树状数组在x_{i}行和y_{i}列后面分别加上本次影响,再w[x_{i}][y_{i}]=w[x_{i}][y_{i}]-z_{i},去除对当前点的重复影响,最后对每个点求所在列和所在行的影响,再与w[i][j](当前点)求和就是本点的影响。

最后乘以(i+j)求和取模即可

#include <bits/stdc++.h>
#define mem(a, b) memset(a, b, sizeof a)
using namespace std;
const int N = 2010;
typedef long long ll;
const int mod = 1e9 + 7;
template <class T>
bool read(T & a){
	a = 0;
	int flag = 0;
	char ch;
	if((ch = getchar()) == '-'){
		flag = 1;
	}
	else if(ch >= '0' && ch <= '9'){
		a = a * 10 + ch - '0';
	}
	while ((ch = getchar()) >= '0' && ch <= '9'){
		a = a * 10 + ch - '0';
	}
	if(flag)a = -a;
	return true;
}
template <class T, class ... R>
bool read(T & a, R & ... b){
	if(!read(a))return 0;
	read(b...);
}
template <class T>
bool out(T a){
	if(a < 0)putchar('-');
	if(a >= 10)out(a / 10);
	putchar(a % 10 + '0');
	return true;
}
template <class T, class ... R>
bool out(T a, R ... b){
	if(!out(a))return 0;
	out(b...);
}
ll n, m, h;
ll w[N][N];
ll a[N][2];
ll lowbit(ll x){
	return x & -x;
}
ll add(ll x, ll val, ll ind){
	if (ind == 0){
		while (x <= n){
			// ά»¤ÐÐ
			a[x][0] += val;
			x += lowbit(x); 
		}
	}
	else {
		while (x <= m){
			a[x][1] += val;
			x += lowbit(x);
		}
	}
}
ll query(ll x, ll ind){
	ll res = 0;
	while (x){
		res += a[x][ind];
		x -= lowbit(x);
	}
	return res;
}
int main()
{
	read(n, m, h);
	mem(w, 0);
	mem(a, 0);
	for (int i = 1; i <= h; i++){
		ll x, y, z;
		read(x, y, z);
		add(x, z, 0);
		add(y, z, 1);
		w[x][y] -= z;
	}
	ll res = 0;
	for (int i = 1; i <= n; i++){
		for (int j = 1; j <= m; j++){
			ll t1 = query(i, 0) - query(i - 1, 0);
			ll t2 = query(j, 1) - query(j - 1, 1);
			w[i][j] += t1 + t2;
			res += w[i][j] % mod * (i + j) % mod;
			res %= mod;
		}
	}
	out(res % mod);
	return 0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基于微信小程序的家政服务预约系统采用PHP语言和微信小程序技术,数据库采用Mysql,运行软件为微信开发者工具。本系统实现了管理员和客户、员工三个角色的功能。管理员的功能为客户管理、员工管理、家政服务管理、服务预约管理、员工风采管理、客户需求管理、接单管理等。客户的功能为查看家政服务进行预约和发布自己的需求以及管理预约信息和接单信息等。员工可以查看预约信息和进行接单。本系统实现了网上预约家政服务的流程化管理,可以帮助工作人员的管理工作和帮助客户查询家政服务的相关信息,改变了客户找家政服务的方式,提高了预约家政服务的效率。 本系统是针对网上预约家政服务开发的工作管理系统,包括到所有的工作内容。可以使网上预约家政服务的工作合理化和流程化。本系统包括手机端设计和电脑端设计,有界面和数据库。本系统的使用角色分为管理员和客户、员工三个身份。管理员可以管理系统里的所有信息。员工可以发布服务信息和查询客户的需求进行接单。客户可以发布需求和预约家政服务以及管理预约信息、接单信息。 本功能可以实现家政服务信息的查询和删除,管理员添加家政服务信息功能填写正确的信息就可以实现家政服务信息的添加,点击家政服务信息管理功能可以看到基于微信小程序的家政服务预约系统里所有家政服务的信息,在添加家政服务信息的界面里需要填写标题信息,当信息填写不正确就会造成家政服务信息添加失败。员工风采信息可以使客户更好的了解员工。员工风采信息管理的流程为,管理员点击员工风采信息管理功能,查看员工风采信息,点击员工风采信息添加功能,输入员工风采信息然后点击提交按钮就可以完成员工风采信息的添加。客户需求信息关系着客户的家政服务预约,管理员可以查询和修改客户需求信息,还可以查看客户需求的添加时间。接单信息属于本系统里的核心数据,管理员可以对接单的信息进行查询。本功能设计的目的可以使家政服务进行及时的安排。管理员可以查询员工信息,可以进行修改删除。 客户可以查看自己的预约和修改自己的资料并发布需求以及管理接单信息等。 在首页里可以看到管理员添加和管理的信息,客户可以在首页里进行家政服务的预约和公司介绍信息的了解。 员工可以查询客户需求进行接单以及管理家政服务信息和留言信息、收藏信息等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值