题目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. 小部件厂 (高斯消元)打卡的更多相关文章

  1. AcWing 209. 装备购买 (高斯消元线性空间)打卡

    脸哥最近在玩一款神奇的游戏,这个游戏里有 n 件装备,每件装备有 m 个属性,用向量z[i]=(ai,1,ai,2,..,ai,m)z[i]=(ai,1,ai,2,..,ai,m) 表示,每个装备需要 ...

  2. CDOJ 1330 柱爷与远古法阵【高斯消元,卡精度】

    柱爷与远古法阵 Time Limit: 125/125MS (Java/Others)     Memory Limit: 240000/240000KB (Java/Others) Submit S ...

  3. AcWing 208. 开关问题 (高斯消元+状压)打卡

    有N个相同的开关,每个开关都与某些开关有着联系,每当你打开或者关闭某个开关的时候,其他的与此开关相关联的开关也会相应地发生变化,即这些相联系的开关的状态如果原来为开就变为关,如果为关就变为开. 你的目 ...

  4. 【BZOJ3640】JC的小苹果 概率DP+高斯消元

    [BZOJ3640]JC的小苹果 Description 让我们继续JC和DZY的故事. “你是我的小丫小苹果,怎么爱你都不嫌多!” “点亮我生命的火,火火火火火!” 话说JC历经艰辛来到了城市B,但 ...

  5. CDOJ 1330 柱爷与远古法阵(高斯消元)

    CDOJ 1330 柱爷与远古法阵(高斯消元) 柱爷与远古法阵 Time Limit: 125/125MS (Java/Others)     Memory Limit: 240000/240000K ...

  6. 单(single):换根dp,表达式分析,高斯消元

    虽说这题看大家都改得好快啊,但是为什么我感觉这题挺难.(我好菜啊) 所以不管怎么说那群切掉这题的大佬是不会看这篇博客的所以我要开始自嗨了. 这题,明显是树dp啊.只不过出题人想看你发疯,询问二合一了而 ...

  7. BZOJ 4031: [HEOI2015]小Z的房间 高斯消元 MartixTree定理 辗转相除法

    4031: [HEOI2015]小Z的房间 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4031 Description 你突然有了一个 ...

  8. 【bzoj4031】[HEOI2015]小Z的房间 Matrix-Tree定理+高斯消元

    [bzoj4031][HEOI2015]小Z的房间 2015年4月30日3,0302 Description 你突然有了一个大房子,房子里面有一些房间.事实上,你的房子可以看做是一个包含n*m个格子的 ...

  9. POJ SETI 高斯消元 + 费马小定理

    http://poj.org/problem?id=2065 题目是要求 如果str[i] = '*'那就是等于0 求这n条方程在%p下的解. 我看了网上的题解说是高斯消元 + 扩展欧几里德. 然后我 ...

随机推荐

  1. java 反射,类的加载过程以及Classloader类加载器

    首先自定义一个类Person package reflection; public class Person { private String name; public int age; public ...

  2. BottomNavigationBar 自定义 底部导航条

    在flutter中,BottomNavigationBar 是底部导航条,可以让我们定义底部 Tab 切换,bottomNavigationBar是 Scaffold 组件的参数. BottomNav ...

  3. Microsoft SQL Server(sql server 关系型数据库管理系统)

    sql server一般指Microsoft SQL Server 关系型数据库管理系统 Microsoft SQL Server 是一个全面的数据库平台,使用集成的商业智能 (BI)工具提供了企业级 ...

  4. element-ui中的loading的实际应用

    实际开发中,要如何指定loading在我们想要的区域加遮罩呢? 前提: 你已经引入element-ui,如下: import ElementUI from 'element-ui' import { ...

  5. 2019 牛客暑期多校 第二场 H Second Large Rectangle (单调栈)

    题目:https://ac.nowcoder.com/acm/contest/882/H 题意:一个大的01矩阵,然后现在要求第二大的全一矩阵是多少 思路:在这里我们首先学习一下另一个东西,怎么求直方 ...

  6. js中的投掷筛子的小游戏

    代码 <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8&qu ...

  7. dubbo 漫谈一

    转:腾信视频 阿甘 https://ke.qq.com/course/216518 https://blog.csdn.net/xlgen157387/article/details/51865289 ...

  8. 左手Mongodb右手Redis 第三章mongdb操作

    mongodb查询操作 1.查询操作 db.getCollection('example_data_1').find({})  查询所有的信息,相当于mysql中的select * from tabl ...

  9. css控制显示超出多少行以后开始出现省略号的写法

    display: -webkit-box; display: -moz-box; text-overflow: -o-ellipsis-lastline; text-overflow: ellipsi ...

  10. 116、TensorFlow变量的版本

    import tensorflow as tf v = tf.get_variable("v", shape=(), initializer=tf.zeros_initialize ...