线性空间和异或空间(线性基)bzoj4004贪心+高斯消元优秀模板
线性空间:是由一组基底构成的所有可以组成的向量空间
对于一个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贪心+高斯消元优秀模板的更多相关文章
- 【bzoj4004】[JLOI2015]装备购买 贪心+高斯消元求线性基
题目描述 脸哥最近在玩一款神奇的游戏,这个游戏里有 n 件装备,每件装备有 m 个属性,用向量zi(aj ,.....,am) 表示 (1 <= i <= n; 1 <= j < ...
- 【BZOJ4004】[JLOI2015]装备购买 贪心+高斯消元
[BZOJ4004][JLOI2015]装备购买 Description 脸哥最近在玩一款神奇的游戏,这个游戏里有 n 件装备,每件装备有 m 个属性,用向量zi(aj ,.....,am) 表示 ( ...
- 【BZOJ2460】[BeiJing2011]元素 贪心+高斯消元求线性基
[BZOJ2460][BeiJing2011]元素 Description 相传,在远古时期,位于西方大陆的 Magic Land 上,人们已经掌握了用魔法矿石炼制法杖的技术.那时人们就认识到,一个法 ...
- [hdu 3949]线性基+高斯消元
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3949 一开始给做出来的线性基wa了很久,最后加了一步高斯消元就过了. 之所以可以这样做,证明如下. 首 ...
- BZOJ 2844 albus就是要第一个出场 ——高斯消元 线性基
[题目分析] 高斯消元求线性基. 题目本身不难,但是两种维护线性基的方法引起了我的思考. void gauss(){ k=n; F(i,1,n){ F(j,i+1,n) if (a[j]>a[i ...
- 洛谷P3389 高斯消元 / 高斯消元+线性基学习笔记
高斯消元 其实开始只是想搞下线性基,,,后来发现线性基和高斯消元的关系挺密切就一块儿在这儿写了好了QwQ 先港高斯消元趴? 这个算法并不难理解啊?就会矩阵运算就过去了鸭,,, 算了都专门为此写个题解还 ...
- 【XSY2701】异或图 线性基 容斥原理
题目描述 定义两个图\(G_1\)与\(G_2\)的异或图为一个图\(G\),其中图\(G\)的每条边在\(G_1\)与\(G_2\)中出现次数和为\(1\). 给你\(m\)个图,问你这\(m\)个 ...
- 【bzoj4004】【JLOI2015】装备购买 (线性基+高斯消元)
Description 脸哥最近在玩一款神奇的游戏,这个游戏里有 n 件装备,每件装备有 m 个属性,用向量zi(aj ,.....,am) 表示 (1 <= i <= n; 1 < ...
- bzoj2115 [Wc2011] Xor——高斯消元 & 异或线性基
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2115 异或两次同一段路径的权值,就相当于没有走这段路径: 由此可以得到启发,对于不同的走法, ...
随机推荐
- mongodb 案例 ~ 经典故障案例
一 简介:此文汇总遇到过和搜集过的故障案例 二 场景案例 1 问题描述: mongo集群在无任何业务情况下,mongos所在服务器cpu突然被打满,内核日志报错 mongos被hung住,非常奇怪的问 ...
- Springboot 配置 ssl 实现HTTPS 请求 & Tomcat配置SSL支持https请求
SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议.TLS与 ...
- [Docker]CentOS7通过rpm包安装Docker
前几天写过一篇文章:[Docker]CentOS7下Docker安装教程,直接使用yum命令下载Docker即可.但是前提是你需要***,所以这篇文章来讲讲,如果不会***,该如何安装Docker. ...
- 【MongoDB】 Failed to connect to 127.0.0.1:27017, reason: Connection refused
由于项目需要,在一台虚拟机上安装了MongoDB,但是在启动的时候,出现如下错误: [root@localhost bin]# ./mongo MongoDB shell version v3.4.0 ...
- k64 datasheet学习笔记52---Universal Asynchronous Receiver/Transmitter (UART)
1.前言 UART实现与外设或CPU的通信 2. UART概述 2.1基本特性 (1)Full-duplex operation (2)Standard mark/space non-return-t ...
- MII与RMII接口的区别【转】
转自:https://blog.csdn.net/fun_tion/article/details/70270632 1.概述 MII即“媒体独立接口”,也叫“独立于介质的接口”.它是IEEE-802 ...
- 游记-NOIP2018
Day -3 受蛊惑跑到理工大去试机,意外发现home里的noilinux账户下有个压缩包,而且还试对了密码,怀着 激动 紧张的心情,打开来看,里面写着 (写出来我就会被禁赛了): asdfasdra ...
- hostapd中扫描的调用过程
扫描结果获取supplicant_event(EVENT_SCAN_RESULTS)wpa_supplicant_event_scan_results_wpa_supplicant_event_sca ...
- T-SQL 日期函数
GETDATE() 它将返回当前日期和时间. 语法 上述函数的语法: GETDATE() 例 以下查询将返回当前日期以及MS SQL Server中的时间. Select getdate() as c ...
- signal & slot
The Qt signals/slots and property system are based on the ability to introspect the objects at runti ...