AcWing 227. 小部件厂 (高斯消元)打卡
题目:https://www.acwing.com/problem/content/description/229/
题意:有很多个零件,每个零件的生产时间都在3-9天之间,现在只知道每个工人的生产部件有哪些,还有生产日期的星期几和完成日期的星期几,求每个部件的具体生产日期
思路:首先我们根据两个星期,我们实际上可以计算出具体时间,然后我们到每个工人生产零件的数目还有时间,相当于我们可以建立这么多个方程组,然后我们就可以消元得出答案
注意处理3-9天范围的细节即可
#include<bits/stdc++.h>
using namespace std;
#define N 305
char day[][]={"","MON","TUE","WED","THU","FRI","SAT","SUN"};
int n,m,k,mat[N][N],ans[N]; int gcd(int a,int b)
{
if(b==)
return a;
else return gcd(b,a%b);
}
bool mul_solu;
bool gauss(int mat[N][N],int m,int n)
{
mul_solu=false;
int row,col;
for(row=,col=;row<m && col<n;++row,++col)
{
int p=row;
for(int j=row+;j<m;++j)
if(abs(mat[j][col])>abs(mat[p][col]))
p=j;
if(p!=row)
{
for(int j=;j<=n;++j)
swap(mat[row][j],mat[p][j]);
}
if(mat[row][col]==) // 最大的都为0,说明这一列以下全是0
{
row--;
continue;
}
for(int j=row+;j<m;++j)
{
int gg=gcd(mat[row][col],mat[j][col]);
int muli=mat[j][col]/gg%;
int mulj=mat[row][col]/gg%;
for(int k=col;k<=n;++k)
{
mat[j][k]=mat[j][k]*mulj-mat[row][k]*muli;
mat[j][k]=(mat[j][k]%+)%;
}
}
}
for(int i=row;i<m;++i) // inconsistent必须先与multiple判断
if(mat[i][n])
return false;
if(row<n) // free variable 少
{
mul_solu=true;
return true;
} for(int i=n-;i>=;--i)
{
bool flag=false;
for(int j=;j<=;++j)
{
int rr=;
for(int k=i+;k<n;++k)
rr+=mat[k][n]*mat[i][k]%,rr%=;
rr+=j*mat[i][i];
if(rr%==mat[i][n])
{
mat[i][n]=j;
flag=true;
break;
}
}
if(!flag)
return false;
} return true;
} int get_time(char *t1,char *t2)
{
int st,ed;
for(int i=;i<=;++i)
{
if(strcmp(t1,day[i])==)
st=i;
if(strcmp(t2,day[i])==)
ed=i;
}
if(ed-st>=)
return ed-st+;
else return ed+-st;
}
char t1[],t2[];
int tt;
int main ()
{
while(scanf("%d%d",&n,&m)!=EOF)
{
if(n== && m==) break;
memset(mat,,sizeof(mat));
for(int i=;i<m;++i)
{
scanf("%d%s%s",&k,t1,t2);
mat[i][n]=get_time(t1,t2)%;
for(int j=;j<=k;++j)
{
scanf("%d",&tt);
mat[i][tt-]++;
mat[i][tt-]%=;
}
}
if(gauss(mat,m,n))
{
if(mul_solu)
{
printf("Multiple solutions.\n");
}
else
{
for(int i=;i<n-;++i)
printf("%d ",mat[i][n]);
printf("%d\n",mat[n-][n]);
}
}
else printf("Inconsistent data.\n");
}
return ;
}
AcWing 227. 小部件厂 (高斯消元)打卡的更多相关文章
- AcWing 209. 装备购买 (高斯消元线性空间)打卡
脸哥最近在玩一款神奇的游戏,这个游戏里有 n 件装备,每件装备有 m 个属性,用向量z[i]=(ai,1,ai,2,..,ai,m)z[i]=(ai,1,ai,2,..,ai,m) 表示,每个装备需要 ...
- CDOJ 1330 柱爷与远古法阵【高斯消元,卡精度】
柱爷与远古法阵 Time Limit: 125/125MS (Java/Others) Memory Limit: 240000/240000KB (Java/Others) Submit S ...
- AcWing 208. 开关问题 (高斯消元+状压)打卡
有N个相同的开关,每个开关都与某些开关有着联系,每当你打开或者关闭某个开关的时候,其他的与此开关相关联的开关也会相应地发生变化,即这些相联系的开关的状态如果原来为开就变为关,如果为关就变为开. 你的目 ...
- 【BZOJ3640】JC的小苹果 概率DP+高斯消元
[BZOJ3640]JC的小苹果 Description 让我们继续JC和DZY的故事. “你是我的小丫小苹果,怎么爱你都不嫌多!” “点亮我生命的火,火火火火火!” 话说JC历经艰辛来到了城市B,但 ...
- CDOJ 1330 柱爷与远古法阵(高斯消元)
CDOJ 1330 柱爷与远古法阵(高斯消元) 柱爷与远古法阵 Time Limit: 125/125MS (Java/Others) Memory Limit: 240000/240000K ...
- 单(single):换根dp,表达式分析,高斯消元
虽说这题看大家都改得好快啊,但是为什么我感觉这题挺难.(我好菜啊) 所以不管怎么说那群切掉这题的大佬是不会看这篇博客的所以我要开始自嗨了. 这题,明显是树dp啊.只不过出题人想看你发疯,询问二合一了而 ...
- BZOJ 4031: [HEOI2015]小Z的房间 高斯消元 MartixTree定理 辗转相除法
4031: [HEOI2015]小Z的房间 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4031 Description 你突然有了一个 ...
- 【bzoj4031】[HEOI2015]小Z的房间 Matrix-Tree定理+高斯消元
[bzoj4031][HEOI2015]小Z的房间 2015年4月30日3,0302 Description 你突然有了一个大房子,房子里面有一些房间.事实上,你的房子可以看做是一个包含n*m个格子的 ...
- POJ SETI 高斯消元 + 费马小定理
http://poj.org/problem?id=2065 题目是要求 如果str[i] = '*'那就是等于0 求这n条方程在%p下的解. 我看了网上的题解说是高斯消元 + 扩展欧几里德. 然后我 ...
随机推荐
- SQL语句中,除数为0时,相应方法
在sql中做除法处理的时候,可能需要处理除数为零的情况. (1).case语句处理方法是用case when ... else 来处理 (2).nullif函数nullif函数有两个参数,定义如下:N ...
- POJ - 1655 (点分治-树的重心)
题目:https://vjudge.net/contest/307753#problem/D 题意:给你一棵树,让你求出一个点,让他的最大子树的节点数尽量小 思路:最大子树节点数尽量小,一看就是树的重 ...
- DZY Loves Math
DZY Loves Math 对于正整数 $n$,定义 $f(n)$ 为 $n$ 所含质因子的最大幂指数. 例如 $f(1960)=f(2^3 * 5^1 * 7^2)=3, f(10007)=1, ...
- Scribd每月共有超过两亿个访客、累积数亿篇以上的文件档案,Alexa全球排名200以内
目前已登上世界300大网站,每月共有超过两亿个访客.累积数亿篇以上的文件档案.透过Flash介面的阅读器-iPaper,使用者可以在网站内浏览各种文件,由于该网站是一个文件分享平台,所有的文件都是由使 ...
- zabbix4.0部署
1.环境检查 uname -r getenforce systemctl status firewalld.service 2.设置解析,自建yum源(可选) /etc/hosts #!/bin/ba ...
- COALESCE 函数作用
用途. 将空值替换成其他值 返回第一个非空值. 任意一个不为空的值.比较有用.
- 定制xfce4桌面==排除appfinder的綑绑
如下等同于安装 xfce4-meta,除了不安装 app-finder emerge -avq xfwm4 xfdesktop xfce4-session xfce4-settings xfce4-t ...
- Cocos2d 之FlyBird开发---GameAbout类
| 版权声明:本文为博主原创文章,未经博主允许不得转载.(笔者才疏学浅,如有错误,请多多指教) 一般像游戏关于的这种界面中,主要显示的是游戏的玩法等. GameAbout.h #ifndef _G ...
- “希希敬敬对”队软件工程第九次作业-beta冲刺第六次随笔
“希希敬敬对”队软件工程第九次作业-beta冲刺第六次随笔 队名: “希希敬敬对” 龙江腾(队长) 201810775001 杨希 201810812008 何敬 ...
- 博弈的dfs
题目: 链接:https://ac.nowcoder.com/acm/contest/283/D来源:牛客网 小西买了一堆肥宅快乐水和肥宅快乐茶,准备和室友比谁更肥宅. 快乐水有A瓶,快乐茶B瓶. 小 ...