线性空间:是由一组基底构成的所有可以组成的向量空间
  对于一个n*m的矩阵,高斯消元后的i个主元可以构成i维的线性空间,i就是矩阵的秩  
  并且这i个主元线性无关

/*
每个向量有权值,求最小权极大线性无关组 本题是使用贪心策略的高斯消元
由输入给出的n个物品,每个物品有m种属性,和价格price
如果a物品的属性可以由其他已有物品的属性组合出,那么a可以不必购买
问最少花掉多少钱,使得所有物品都可以组合出
首先构建n*m矩阵,然后高斯消元
在求第i个主元时,取价格最小的那个即可
可用反证法证明
*/
#include<bits/stdc++.h>
using namespace std;
#define maxn 1005
#define ld long double
#define esp 1e-6
struct Vec{//带权向量
ld a[maxn];
int w;
bool operator<(const Vec & x)const {
return w<x.w;
}
}p[maxn];
int n,m; int main(){
cin>>n>>m;
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
cin>>p[i].a[j];
for(int i=;i<=n;i++)scanf("%d",&p[i].w);
sort(p+,p++n);//按权值从小到大排即可
int ans=,cnt=;
//高斯消元!
int i=,j=,Max,Maxw;
for(;i<=n && j<=m;i++,j++){
Max=i;
if(fabs(p[Max].a[j])>esp)//这里一定要加fabs,因为可能会有赋值
Maxw=p[Max].w;
else Maxw=; for(int k=i+;k<=n;k++)
if(fabs(p[k].a[j])>esp && p[k].w<Maxw){Max=k;Maxw=p[k].w;}
if(fabs(p[Max].a[j])<esp){i--;continue;} ans+=Maxw;cnt++;
if(Max!=i)//把Max换到第i行
swap(p[i],p[Max]); for(int k=;k<=n;k++)//把每行的第j个数消为0
if(k!=i){
ld r=(ld)p[k].a[j]/p[i].a[j];
for(int t=;t<=m;t++)
p[k].a[t]-=r*p[i].a[t];
p[k].a[j]=;
}
} printf("%d %d\n",cnt,ans);
}

网上找到一中贼快的高斯消元写法。。以后就用它了

思路是枚举矩阵上的每个元素,对于每个非0的A[i][j],如果A[i][j]可以作为主元,那么就把F[j](即第j列上的主元)标记为i,因为剩下的位如何已经不重要了,所以直接退出本轮循环,继续下一行

若A[i][j]不可以作主元,说明第j列已经有主元了,那么就用那个主元所在的行F[j]来消A[i][j]

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
#include<cmath>
using namespace std;
#define double long double
const double eps=1e-;
struct str
{
double a[];
int v;
bool operator < (const str &s) const
{
return v<s.v;
}
}a[];
int n,m,f[];
int main()
{
int i,j,k,ans1=,ans2=;
double x;
cin>>n>>m;
for (i=;i<=n;i++)
for (j=;j<=m;j++)
cin>>a[i].a[j];
for (i=;i<=n;i++)
cin>>a[i].v;
sort(a+,a+n+);
for (i=;i<=n;i++)
for (j=;j<=m;j++)
if (fabs(a[i].a[j])>eps)
{
if (!f[j])//如果第j列还没有被作为秩,并且第i行第j列非0
{
f[j]=i;
ans1++;
ans2+=a[i].v;
break;
}
else//反之就用A[f[j]][j]来消去A[i][j]
{
x=a[i].a[j]/a[f[j]].a[j];
for (k=j;k<=m;k++)
a[i].a[k]-=a[f[j]].a[k]*x;
}
}
cout<<ans1<<" "<<ans2<<endl;
}

线性空间和异或空间(线性基)bzoj4004贪心+高斯消元优秀模板的更多相关文章

  1. 【bzoj4004】[JLOI2015]装备购买 贪心+高斯消元求线性基

    题目描述 脸哥最近在玩一款神奇的游戏,这个游戏里有 n 件装备,每件装备有 m 个属性,用向量zi(aj ,.....,am) 表示 (1 <= i <= n; 1 <= j < ...

  2. 【BZOJ4004】[JLOI2015]装备购买 贪心+高斯消元

    [BZOJ4004][JLOI2015]装备购买 Description 脸哥最近在玩一款神奇的游戏,这个游戏里有 n 件装备,每件装备有 m 个属性,用向量zi(aj ,.....,am) 表示 ( ...

  3. 【BZOJ2460】[BeiJing2011]元素 贪心+高斯消元求线性基

    [BZOJ2460][BeiJing2011]元素 Description 相传,在远古时期,位于西方大陆的 Magic Land 上,人们已经掌握了用魔法矿石炼制法杖的技术.那时人们就认识到,一个法 ...

  4. [hdu 3949]线性基+高斯消元

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3949 一开始给做出来的线性基wa了很久,最后加了一步高斯消元就过了. 之所以可以这样做,证明如下. 首 ...

  5. BZOJ 2844 albus就是要第一个出场 ——高斯消元 线性基

    [题目分析] 高斯消元求线性基. 题目本身不难,但是两种维护线性基的方法引起了我的思考. void gauss(){ k=n; F(i,1,n){ F(j,i+1,n) if (a[j]>a[i ...

  6. 洛谷P3389 高斯消元 / 高斯消元+线性基学习笔记

    高斯消元 其实开始只是想搞下线性基,,,后来发现线性基和高斯消元的关系挺密切就一块儿在这儿写了好了QwQ 先港高斯消元趴? 这个算法并不难理解啊?就会矩阵运算就过去了鸭,,, 算了都专门为此写个题解还 ...

  7. 【XSY2701】异或图 线性基 容斥原理

    题目描述 定义两个图\(G_1\)与\(G_2\)的异或图为一个图\(G\),其中图\(G\)的每条边在\(G_1\)与\(G_2\)中出现次数和为\(1\). 给你\(m\)个图,问你这\(m\)个 ...

  8. 【bzoj4004】【JLOI2015】装备购买 (线性基+高斯消元)

    Description 脸哥最近在玩一款神奇的游戏,这个游戏里有 n 件装备,每件装备有 m 个属性,用向量zi(aj ,.....,am) 表示 (1 <= i <= n; 1 < ...

  9. bzoj2115 [Wc2011] Xor——高斯消元 & 异或线性基

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2115 异或两次同一段路径的权值,就相当于没有走这段路径: 由此可以得到启发,对于不同的走法, ...

随机推荐

  1. mouseover,mouseout与mouseenter,mouseleave

    针对单个元素,使用感一样. 差异提现在有子元素的情况下: mouseover和mouseout在父元素和其子元素都可以触发,当鼠标穿过一个元素时,触发次数得依子元素数量而言. mouseenter和m ...

  2. Css/Js推荐类库

    animate.css https://daneden.github.io/animate.css WOW.js http://mynameismatthieu.com/WOW owl.carouse ...

  3. Redis 深度历险

    学习资料 https://juejin.im/book/5afc2e5f6fb9a07a9b362527 包括下面几方面的内容 基础 应用 原理 集群 拓展 源码 to be done

  4. mongodb系列~ mongodb慢语句(1)

    1 简介:讲讲mongo的慢日志2 慢日志类型    query insert update delete 3 查看慢日志  1 db.system.profile.find() 慢日志总揽  2 d ...

  5. Flask表单(form)的应用

    导入模块request模块 #指定请求方式,使用methods属性 @app.route("/",methods=['GET','POST']) def index(): #判断c ...

  6. Javascript - ExtJs - 整合百度文章编辑器

    ExtJs - 整合百度文章编辑器(ExtJs UEditor) 第一步:去官网下载最新版本的UEditor,UEditor下载. 第二步:在编辑器根目录创建一个Extjs-Editor.js,录入以 ...

  7. Navicat for MySQL 12中文版 破解流程

    1.下载  Keygen_Patch 软件 下载地址 pass: saxz 2.启动 Keygen_Patch 软件 3.提示破解成功了,先别着急 4.运行 Navica  软件,输入注册码 5.断网 ...

  8. Java基础3-数组操作;类概述

    昨日内容回顾 数据类型 基本数据类型 1) byte, short, int, long, float, double 2) boolean[true, false] 3) char 100: 默认为 ...

  9. python print输出带颜色 总结

    书写格式:      开头部分:\033[显示方式;前景色;背景色m + 结尾部分:\033[0m      注意:开头部分的三个参数:显示方式,前景色,背景色是可选参数,可以只写其中的某一个:另外由 ...

  10. 【转】Python用数据说明程序员需要掌握的技能

    [转]Python用数据说明程序员需要掌握的技能 https://blog.csdn.net/HuangZhang_123/article/details/80497951 当下是一个大数据的时代,各 ...