习题8-16(uva-1618)

本文介绍了一个名为STTable的自定义数据结构,用于高效地处理区间内的最小最大值查询。通过位运算和动态规划,它在O(log n)时间内完成查询,适用于处理整数数组问题。博客重点讲解了初始化、查询方法以及应用场景。
#include <iostream>
#include <istream>
#include <sstream>
#include <vector>
#include <stack>
#include <list>
#include <map>
#include <set>
#include <deque>
#include <queue>
#include <cstring>
#include <unordered_map>
#include <unordered_set>
#include <algorithm>
#include <numeric>
#include <chrono>
#include <ctime>
#include <cmath>
#include <cctype>
#include <string>
#include <cstdio>
#include <iomanip>


#include <thread>
#include <mutex>
#include <condition_variable>
#include <functional>
#include <iterator>
using namespace std;
class STTable
{
	const int STMAXSIZE = 20;
public:
	
	STTable() {}
	~STTable() {
		lg2.clear();
		dpmin.clear();
		dpmax.clear();
	};
	void Init(int* input, int cnt)
	{
		lg2.assign(cnt + 1, -1);
		dpmin.assign(cnt, vector<int>(STMAXSIZE, 0));
		dpmax.assign(cnt, vector<int>(STMAXSIZE, 0));

		for (int i = 1; i <= cnt; i++)
			lg2[i] = lg2[i - 1] + (i & (i - 1) ? 0 : 1);

		for (int i = 0; i < cnt; i++) {
			dpmin[i][0] = dpmax[i][0] = input[i];
		}

		int len = lg2[cnt];
		for (int i = 1; i <= len; i++) {
			for (int j = 0; lg2[cnt - j] >= i; j++)
			{
				dpmin[j][i] = min(dpmin[j][i - 1], dpmin[j + (1 << (i - 1))][i - 1]);
				dpmax[j][i] = max(dpmax[j][i - 1], dpmax[j + (1 << (i - 1))][i - 1]);
			}
		}
	}
	int GetMin(int l, int r) {
		int k = lg2[r - l + 1];    //找到当前区间最大的倍增长度
		return min(dpmin[l][k], dpmin[r - (1 << k) + 1][k]);
	}
	int GetMax(int l, int r) {
		int k = lg2[r - l + 1];    //找到当前区间最大的倍增长度
		return max(dpmax[l][k], dpmax[r - (1 << k) + 1][k]);
	}
private:
	vector<int> lg2;
	vector<vector<int> > dpmin,dpmax;
};

const int maxn = 1e4 + 7,maxm = 100010;
int n,input[maxn],pos[maxm];

int main()
{
	int t;
	STTable st;
	cin >> t;
	while (t--) {
		cin >> n;
		for (int i = 0; i < n; i++) {
			cin >> input[i];
			//每个输入都不同 所有每个下标不会出现覆盖的情况
			pos[input[i]] = i;
		}
		st.Init(input, n);
		bool ok = false;
		for (int i = 0; i < n; i++) {
			for (int j = i + 3; j < n; j++) {
				int tmin = st.GetMin(i, j);
				int tmax = st.GetMax(i, j);
				// p q r s   p == i   s == j
				// q > s > p > r
				//排列 q  >  input[j] > input[i] > r
				//tmax > input[j] > input[i] > tmin 
				//i pos[tmax] pos[tmin ] j
				//极端情况 tmin = input[i] pos[tmax] 无法排在pos[tmin]前面
 				if (input[j] > input[i]  && pos[tmax] < pos[tmin]) {
					ok = true;
					break;
				}
				// q < s < p < r
				//排列 q  <  input[j] < input[i] < r
				//tmin < input[j] < input[i] < tmax
				// q ==> tmin  r ==>tmax  
				//i pos[tmin] pos[tmax] j
				//因为input[j] < input[i]  tmax 不会是 input[j]
				//tmin 不会是 input[i]
				if (input[j] < input[i] &&  pos[tmin] < pos[tmax] ) {
					ok = true;
					break;
				}
			}
			if (ok) break;
		}
		if (ok) cout << "YES" << endl;
		else cout << "NO" << endl;
	}
	return 0;
}
考虑可再生能源出力不确定性的商业园区用户需求响应策略(Matlab代码实现)内容概要:本文围绕“考虑可再生能源出力不确定性的商业园区用户需求响应策略”展开,结合Matlab代码实现,研究在可再生能源(如风电、光伏)出力具有不确定性的背景下,商业园区如何制定有效的需求响应策略以优化能源调度和提升系统经济性。文中可能涉及不确定性建模(如场景生成与缩减)、优化模型构建(如随机规划、鲁棒优化)以及需求响应机制设计(如价格型、激励型),并通过Matlab仿真验证所提策略的有效性。此外,文档还列举了大量相关的电力系统、综合能源系统优化调度案例与代码资源,涵盖微电网调度、储能配置、负荷预测等多个方向,形成一个完整的科研支持体系。; 适合人群:具备一定电力系统、优化理论和Matlab编程基础的研究生、科研人员及从事能源系统规划与运行的工程技术人员。; 使用场景及目标:①学习如何建模可再生能源的不确定性并应用于需求响应优化;②掌握使用Matlab进行商业园区能源系统仿真与优化调度的方法;③复现论文结果或开展相关课题研究,提升科研效率与创新能力。; 阅读建议:建议结合文中提供的Matlab代码实例,逐步理解模型构建与求解过程,重点关注不确定性处理方法与需求响应机制的设计逻辑,同时可参考文档中列出的其他资源进行扩展学习与交叉验证。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值