【UOJ#179】线性规划 单纯形
题目链接:
Solution
就是单纯形模板题,这篇博客就是存一下板子。
Code
- #include<iostream>
- #include<cstdio>
- #include<cstring>
- #include<cmath>
- #include<algorithm>
- #include<vector>
- using namespace std;
- #define eps 1e-9
- inline int read()
- {
- int x=0,f=1; char ch=getchar();
- while (ch<'0' || ch>'9') {if (ch=='-') f=-1; ch=getchar();}
- while (ch>='0' && ch<='9') {x=x*10+ch-'0'; ch=getchar();}
- return x*f;
- }
- int N,M,id[11000];
- double a[1100][1100],c[1100],b[1100],v,ans[1100];
- inline void Pivot(int l,int e)
- {
- swap(id[e],id[N+l]);
- double r=a[l][e];
- a[l][e]=1;
- for (int i=1; i<=N; i++) a[l][i]/=r;
- b[l]/=r;
- for (int i=1; i<=M; i++)
- if (i!=l) {
- r=a[i][e];
- a[i][e]=0,b[i]-=r*b[l];
- for (int j=1; j<=N; j++) a[i][j]-=r*a[l][j];
- }
- r=c[e];
- c[e]=0;
- for (int i=1; i<=N; i++) c[i]-=r*a[l][i];
- v+=r*b[l];
- }
- inline int Simplex()
- {
- int l,e; double k;
- while (1) {
- l=e=0; k=-eps;
- for (int i=1; i<=M; i++)
- if (b[i]<k) k=b[i],l=i;
- if (!l) break;
- k=-eps;
- for (int i=1; i<=N; i++)
- if (a[l][i]<k && (!e || (rand()&1))) k=a[l][i],e=i;
- if (!e) {puts("Infeasible"); return 1;}
- Pivot(l,e);
- }
- while (1) {
- for (int i=1; i<=N; i++) {
- if (c[i]>eps) {e=i; break;}
- if (i==N) {printf("%.8lf\n",v); return 0;}
- }
- double re=1e18; l=0;
- for (int i=1; i<=M; i++)
- if (a[i][e]>eps && b[i]/a[i][e]<re)
- re=b[i]/a[i][e],l=i;
- if (!l) {puts("Unbounded"); return 2;}
- Pivot(l,e);
- }
- }
- int main()
- {
- N=read(),M=read(); int type=read();
- for (int i=1; i<=N; i++) scanf("%lf",&c[i]),id[i]=i;
- for (int i=1; i<=M; i++) {
- for (int j=1; j<=N; j++) scanf("%lf",&a[i][j]);
- scanf("%lf",&b[i]);
- }
- int flag=Simplex();
- if (flag || !type) return 0;
- for (int i=1; i<=M; i++) ans[id[N+i]]=b[i];
- for (int i=1; i<=N; i++) printf("%.8lf ",ans[i]);
- return 0;
- }
【UOJ#179】线性规划 单纯形的更多相关文章
- UOJ.179.线性规划(单纯形)
题目链接 这写得还不错:http://www.cnblogs.com/zzqsblog/p/5457091.html 引入基变量\(x_{i+n}\),将约束\(\sum_{i=1}^m a_{ij} ...
- UOJ#179. 线性规划[模板]
传送门 http://uoj.ac/problem/179 震惊,博主竟然还不会线性规划! 单纯形实在学不会啊……背个板子当黑盒用…… 学(chao)了NanoApe dalao的板子 #includ ...
- UOJ#179. 线性规划(线性规划)
描述 提交 自定义测试 这是一道模板题. (这个题现在标程挂了..哪位哥哥愿意提供一下靠谱的标程呀?) 本题中你需要求解一个标准型线性规划: 有 nn 个实数变量 x1,x2,…,xnx1,x2,…, ...
- uoj#179 线性规划
这是一道模板题. 本题中你需要求解一个标准型线性规划: 有nn个实数变量x1,x2,⋯,xnx1,x2,⋯,xn和mm条约束,其中第ii条约束形如∑nj=1aijxj≤bi∑j=1naijxj≤bi. ...
- 【UOJ #179】线性规划 单纯形模板
http://uoj.ac/problem/179 终于写出来了单纯性算法的板子,抄的网上大爷的qwq 辅助线性规划找非基变量时要加个随机化才能A,我也不知道为什么,卡精度吗? 2017-3-6UPD ...
- 【UOJ 179】 #179. 线性规划 (单纯形法)
http://uoj.ac/problem/179 补充那一列修改方法: 对于第i行: $$xi=bi-\sum Aij*xj$$ $$=bi-\sum_{j!=e} Aij*xj-Aie*xe ...
- UVA 10498 Happiness(线性规划-单纯形)
Description Prof. Kaykobad has given Nasa the duty of buying some food for the ACM contestents. Nasa ...
- Note -「线性规划」学习笔记
\(\mathcal{Definition}\) 线性规划(Linear Programming, LP)形式上是对如下问题的描述: \[\operatorname{maximize}~~~~z= ...
- 线性规划VB求解
线性规划VB求解 Rem 定义动态数组 Dim a() As Single, c() As Single, b() As Single, cb() As Single Dim aa() As Sing ...
随机推荐
- Content-Type:几种常用数据编码格式
Content-Type: 用于定义用户的浏览器或相关设备如何显示将要加载的数据,或者如何处理将要加载的数据. 内容类型,一般指网页中存在的Content-Type,Content-Type属性指定请 ...
- Spark记录-Scala循环语句
Scala while循环语句 当给定条件为真时,while循环重复一个语句或一组语句.它在执行循环体之前测试条件状态. 只要给定的条件为真,while循环语句重复执行目标语句. object Dem ...
- 在ajax请求后台时在请求标头RequestHeader加token
情景:为了保证系统数据的安全性,一般前后台之间的数据访问会有授权与验证,这里的Token机制相对于Cookie支持跨域访问,在RESTful API里面,验证一般可以使用POST请求来通过验证,使服务 ...
- php-fpm的status可以查看汇总信息和详细信息
nginx.conf 配置文件 server { listen ; server_name localhost; index index.php index.html; root /home/tiny ...
- livereload使用方法
搞这个自动刷新的插件搞了好几个小时了还没搞明白,快被气死了,想改用browser-sync结果npm又一直转啊转一直卡死. 刚才终于神奇地搞定了,结果发现还是我自己智商太低...大概的经过是这样的.. ...
- JavaScript内部原理实践——真的懂JavaScript吗?(转)
通过翻译了Dmitry A.Soshnikov的关于ECMAScript-262-3 JavaScript内部原理的文章, 从理论角度对JavaScript中部分特性的内部工作机制有了一定的了解. 但 ...
- SDWebImage源码阅读-第二篇
一 SDWebImageManager的downloadImageWithURL的方法 上一篇,我们刚开了个头,分析了一下开始加载图片之前如何取消其他正在下载的任务,接着,我们回到 - (void) ...
- [转]CMake cache
CMakeCache.txt 可以将其想象成一个配置文件(在Unix环境下,我们可以认为它等价于传递给configure的参数). CMakeLists.txt 中通过 set(... CACHE . ...
- 关于Mysql5.6半同步主从复制的开启方法【转】
介绍 先了解一下mysql的主从复制是什么回事,我们都知道,mysql主从复制是基于binlog的复制方式,而mysql默认的主从复制方式,其实是异步复制. 主库实际上并不关心从库是否把数据拉完没有, ...
- how-to-pass-a-class-variable-to-a-decorator-inside-class-definition
https://stackoverflow.com/questions/17522706/how-to-pass-a-class-variable-to-a-decorator-inside-clas ...