BZOJ 3112 Zjoi2013 防守战线 单纯形

题目大意:

单纯形*2。。。

#include <cmath>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#define EPS 1e-7
#define INF 1e10
using namespace std;
int n,m;
namespace Linear_Programming{
	double A[1010][10100],b[1010],c[10100],v;
	void Pivot(int l,int e)
	{
		int i,j;

		b[l]/=A[l][e];
		for(i=1;i<=n;i++)
			if(i!=e)
				A[l][i]/=A[l][e];
		A[l][e]=1/A[l][e];

		for(i=1;i<=m;i++)
			if(i!=l&&fabs(A[i][e])>EPS)
			{
				b[i]-=A[i][e]*b[l];
				for(j=1;j<=n;j++)
					if(j!=e)
						A[i][j]-=A[i][e]*A[l][j];
				A[i][e]=-A[i][e]*A[l][e];
			}

		v+=c[e]*b[l];
		for(i=1;i<=n;i++)
			if(i!=e)
				c[i]-=c[e]*A[l][i];
		c[e]=-c[e]*A[l][e];
	}
	double Simplex()
	{
		int i,l,e;
		while(1)
		{
			for(i=1;i<=n;i++)
				if(c[i]>EPS)
					break;
			if((e=i)==n+1)
				return v;
			double temp=INF;
			for(i=1;i<=m;i++)
				if( A[i][e]>EPS && b[i]/A[i][e]<temp )
					temp=b[i]/A[i][e],l=i;
			if(temp==INF) return INF;
			Pivot(l,e);
		}
	}
}
int main()
{
	using namespace Linear_Programming;
	int i,j,x,y,z;
	cin>>m>>n;
	for(i=1;i<=m;i++)
		scanf("%lf",&b[i]);
	for(i=1;i<=n;i++)
	{
		scanf("%d%d%d",&x,&y,&z);
		for(j=x;j<=y;j++)
			A[j][i]=1;
		c[i]=z;
	}
	double ans=Simplex();
	cout<<(long long)(ans+0.5)<<endl;
	return 0;
}
时间: 2024-12-23 04:14:22

BZOJ 3112 Zjoi2013 防守战线 单纯形的相关文章

BZOJ 3112: [Zjoi2013]防守战线 [单纯形法]

题目描述 战线可以看作一个长度为n 的序列,现在需要在这个序列上建塔来防守敌兵,在序列第i 号位置上建一座塔有Ci 的花费,且一个位置可以建任意多的塔,费用累加计算.有m 个区间[L1, R1], [L2, R2], …, [Lm, Rm],在第i 个区间的范围内要建至少Di 座塔.求最少花费. 输入输出格式 输入格式: 第一行为两个数n, m. 接下来一行,有n 个数,描述C 数组. 接下来m 行,每行三个数Li,Ri,Di,描述一个区间. 输出格式: 仅包含一行,一个数,为最少花费. 输入输

BZOJ 3112 [Zjoi2013]防守战线 线性规划

题意: 简单叙述: 一个长度为n的序列,在每个点建塔的费用为Ci,有m个区间,每个区间内至少有Dj个塔,求最小花费. 方法:线性规划 解析: 与上一题类似,同样使用对偶原理解题,解法不再赘述. 代码: #include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #define N 1010 #define M 10010 #define INF 0x7f7f7f7

单纯形 BZOJ3112: [Zjoi2013]防守战线

题面自己上网查. 学了一下单纯形.当然 证明什么的 显然是没去学.不然估计就要残废了 上学期已经了解了 什么叫标准型. 听起来高大上 其实没什么 就是加入好多松弛变量+各种*(-1),使得最后成为一般形式: 给定A[][],求满足A[i][j]*Xj<=A[i][0];(0<i<=n,0<j<=m) 使A[0][j]*Xj最大的X[]: 如果题面中直接得出的条件是A[i][j]*Xj>=A[i][0]; 使 A[0][j]*Xj最小. 那么就要用对偶定理,变成 A[i]

BZOJ3112 [ZJOI2013]防守战线

Description 战线可以看作一个长度为 n 的序列,现在需要在这个序列上建塔来防守敌兵,在序列第 i号位置上建一座塔有 Ci 的花费,且一个位置可以建任意多的塔费用累加计算.有 m个区间[L1, R1], [L2, R2], -, [Lm, Rm],在第 i 个区间的范围内要建至少 Di座塔.求最少花费. Input 第一行为两个数n,m. 接下来一行,有 n个数,描述 C数组. 接下来 m行,每行三个数 Li,Ri,Di,描述一个区间. Output 仅包含一行,一个数,为最少花费.

[ZJOI2013]防守战线

题目描述 战线可以看作一个长度为n 的序列,现在需要在这个序列上建塔来防守敌兵,在序列第i 号位置上建一座塔有Ci 的花费,且一个位置可以建任意多的塔,费用累加计算.有m 个区间[L1, R1], [L2, R2], …, [Lm, Rm],在第i 个区间的范围内要建至少Di 座塔.求最少花费. 输入输出格式 输入格式: 第一行为两个数n, m. 接下来一行,有n 个数,描述C 数组. 接下来m 行,每行三个数Li,Ri,Di,描述一个区间. 输出格式: 仅包含一行,一个数,为最少花费. 输入输

数学(线性规划): ZJOI2013 防守战线

偷懒用的线性规划. 1 #include <iostream> 2 #include <cstring> 3 #include <cstdio> 4 using namespace std; 5 const int maxr=1010; 6 const int maxc=10010; 7 8 int n,m,nxt[maxc]; 9 int a[maxr][maxc]; 10 11 12 void Pivot(int l,int e){ 13 int pre=maxc-

bzoj3550: [ONTAK2010]Vacation&amp;&amp;bzoj3112: [Zjoi2013]防守战线

学了下单纯形法解线性规划 看起来好像并不是特别难,第二个code有注释.我还有...*=-....这个不是特别懂 第一个是正常的,第二个是解对偶问题的 #include<cstdio> #include<iostream> #include<cstring> #include<cstdlib> #include<algorithm> #include<cmath> using namespace std; const double e

树套树专题——bzoj 3110: [Zjoi2013] K大数查询 &amp; 3236 [Ahoi2013] 作业 题解

[原题1] 3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec  Memory Limit: 512 MB Submit: 978  Solved: 476 Description 有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c 如果是2 a b c形式,表示询问从第a个位置到第b个位置,第C大的数是多少. Input 第一行N,M 接下来M行,每行形如1 a b c或2 a b c Outpu

BZOJ 3110: [Zjoi2013]K大数查询( 树状数组套主席树 )

BIT+(可持久化)权值线段树, 用到了BIT的差分技巧. 时间复杂度O(Nlog^2(N)) ----------------------------------------------------------------------------------------- #include<cstdio> #include<cctype> #include<cstring> #include<algorithm> using namespace std;