HDU1754 I Hate It

/*线段树 单点更新 + 寻找区间最值*/
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>

using namespace std;

const int maxn = 200000 + 5;

struct node {
	int l, r, Max, score;
};

node tree[maxn * 4];
int n, m, ans;

void build(int l, int r, int root)
{
	tree[root].l = l;
	tree[root].r = r;

	if (l == r) {
		scanf("%d", &tree[root].score);
		tree[root].Max = tree[root].score;
		return;
	}

	int mid = (tree[root].l + tree[root].r) >> 1;
	build(l, mid, root << 1);
	build(mid + 1, r, root << 1 | 1);
	tree[root].Max = max(tree[root << 1].Max, tree[root << 1 | 1].Max);
}

void query(int l, int r, int root, int L, int R)
{
	if (L <= tree[root].l && R >= tree[root].r) {
		ans = max(ans, tree[root].Max);
		return;
	}

	int mid = (tree[root].l + tree[root].r) >> 1;
	if (R <= mid)
		query(l, mid, root << 1, L, R);
	else if (L > mid)
		query(mid  + 1 , r, root << 1 | 1, L, R);
	else {
		query(l, mid, root << 1, L, R);
		query(mid + 1, r, root << 1 | 1, L, R);
	}
}

void update(int l, int r, int root, int pos, int add)
{
	if (l == r) {
		tree[root].score = tree[root].Max = add;
		return;
	}
	
	int mid = (tree[root].l + tree[root].r) >> 1;
	if (pos <= mid)
		update(l, mid, root << 1, pos, add);
	else
		update(mid + 1, r, root << 1 | 1, pos, add);
	tree[root].Max = max(tree[root << 1].Max, tree[root << 1 | 1].Max);
}


int main()
{
	while (cin >> n >> m) {
		build(1, n, 1);

		int x, y;
		char s[10];
		for (int i = 0; i < m; ++i) {
			scanf("%s", s);
			scanf("%d%d", &x, &y);

			if (s[0] == 'Q') {
				ans = -1;
				query(1, n, 1, x, y);
				printf("%d\n", ans);
			}
			else {
				update(1, n, 1, x, y);
			}
		}
	}
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【1】项目代码完整且功能都验证ok,确保稳定可靠运行后才上传。欢迎下载使用!在使用过程中,如有问题或建议,请及时私信沟通,帮助解答。 【2】项目主要针对各个计算机相关专业,包括计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网等领域的在校学生、专业教师或企业员工使用。 【3】项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 【4】如果基础还行,或热爱钻研,可基于此项目进行二次开发,DIY其他不同功能,欢迎交流学习。 【注意】 项目下载解压后,项目名字和项目路径不要用中文,否则可能会出现解析不了的错误,建议解压重命名为英文名字后再运行!有问题私信沟通,祝顺利! 基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值