UVA 1564 - Widget Factory

题目链接

题意:n种零件, 给定m个制作时间。每段时间制作k个零件,每种零件有一个制作时间,每段时间用Mon到Sun表示,求每一个零件的制作时间。还要推断一下多解和无解的情况

思路:对于每段时间列出一个方程,这样一共列出m个方程解n个变元,利用高斯消元去求解。注意每一个方程都是MOD 7的,所以在高斯消元过程中遇到除法要求该数字%7的逆元去进行运算

代码:

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std; const int N = 305;
char week[7][5] = {"MON", "TUE", "WED", "THU", "FRI", "SAT", "SUN"}; int n, m, k, A[N][N], cnt[N];
char day1[5], day2[5]; int find(char *day) {
for (int i = 0; i < 7; i++)
if (strcmp(week[i], day) == 0)
return i;
} int inv(int x) {
int ans = 1;
for (int i = 0; i < 5; i++)
ans = ans * x % 7;
return ans;
} void build() {
for (int i = 0; i < m; i++) {
scanf("%d%s%s", &k, day1, day2);
A[i][n] = (find(day2) - find(day1) + 8) % 7;
int tmp;
memset(cnt, 0, sizeof(cnt));
while (k--) {
scanf("%d", &tmp);
cnt[tmp]++;
}
for (int j = 1; j <= n; j++)
A[i][j - 1] = cnt[j] % 7;
}
} int gauss() {
int i = 0, j = 0;
while (i < m && j < n) {
int r;
for (r = i; r < m; r++)
if (A[r][j]) break;
if (r == m) {
j++;
continue;
}
for (int k = j; k <= n; k++) swap(A[r][k], A[i][k]);
for (int k = 0; k < m; k++) {
if (i == k) continue;
if (A[k][j]) {
int tmp = A[k][j] * inv(A[i][j]) % 7;
for (int x = j; x <= n; x++)
A[k][x] = ((A[k][x] - tmp * A[i][x]) % 7 + 7) % 7;
}
}
i++;
}
for (int k = i; k < m; k++)
if (A[k][n]) return 2;
if (i < n) return 1;
for (int i = 0; i < n; i++) {
int ans = A[i][n] * inv(A[i][i]) % 7;
if (ans < 3) ans += 7;
printf("%d%c", ans, i == n - 1 ? '\n' : ' ');
}
return 0;
} void solve() {
int tmp = gauss();
if (tmp == 1) printf("Multiple solutions.\n");
else if (tmp == 2) printf("Inconsistent data.\n");
} int main() {
while (~scanf("%d%d", &n, &m) && n) {
build();
solve();
}
return 0;
}

UVA 1564 - Widget Factory(高斯消元)的更多相关文章

  1. POJ 2947 2947 Widget Factory 高斯消元

    给出组件的数量n,给出记录的数量m(n就是变元数量,m是方程数量).每一个记录代表一个方程,求每个组件的生产天数. 高斯消元即可 #include <cstdio> #include &l ...

  2. Poj 2947 widget factory (高斯消元解同模方程)

    题目连接: http://poj.org/problem?id=2947 题目大意: 有n种类型的零件,m个工人,每个零件的加工时间是[3,9],每个工人在一个特定的时间段内可以生产k个零件(可以相同 ...

  3. POJ2947Widget Factory(高斯消元解同模方程)

    http://poj.org/problem?id=2947 题目大意:有n 种装饰物,m 个已知条件,每个已知条件的描述如下:p start enda1,a2......ap (1<=ai&l ...

  4. POJ 2947-Widget Factory(高斯消元解同余方程式)

    题目地址:id=2947">POJ 2947 题意:N种物品.M条记录,接写来M行,每行有K.Start,End,表述从星期Start到星期End,做了K件物品.接下来的K个数为物品的 ...

  5. UVA 1358 - Generator(dp+高斯消元+KMP)

    UVA 1358 - Generator option=com_onlinejudge&Itemid=8&page=show_problem&category=524& ...

  6. POJ 2947 Widget Factory(高斯消元)

    Description The widget factory produces several different kinds of widgets. Each widget is carefully ...

  7. 【POJ】2947 Widget Factory(高斯消元)

    http://poj.org/problem?id=2947 各种逗啊..还好1a了.. 题意我就不说了,百度一大把. 转换为mod的方程组,即 (x[1,1]*a[1])+(x[1,2]*a[2]) ...

  8. UVA 10828 - Back to Kernighan-Ritchie(概率+高斯消元)

    UVA 10828 - Back to Kernighan-Ritchie 题目链接 题意:给图一个流程图,有结点的流程,每次进入下一个流程概率是均等的,有q次询问,求出每次询问结点的运行期望 思路: ...

  9. uva 1560 - Extended Lights Out(枚举 | 高斯消元)

    题目链接:uva 1560 - Extended Lights Out 题目大意:给定一个5∗6的矩阵,每一个位置上有一个灯和开关,初始矩阵表示灯的亮暗情况,假设按了这个位置的开关,将会导致周围包含自 ...

随机推荐

  1. 杠杆(leverage)就是支付保证金借钱进行交易,以小博大

    杠杆(leverage)就是支付保证金借钱进行交易,以小博大: 比如你自己有100块,在向券商借100块,这就是杠杆交易了,杠杆简单地说来就是一个乘号,使用这个工具,可以放大投资的结果,无论最终的结果 ...

  2. 笔记四:onsubmit和onclick的区别

    今天碰到关于表单提交的问题,我是用submit还是用onclick好呢,然后我去百度了一下两者的区别: onsubmit只能表单上使用,提交表单前会触发, onclick是按钮等控件使用, 用来触发点 ...

  3. MySQL各个版本的区别

     文章出自:http://blog.sina.com.cn/s/blog_62b37bfe0101he5t.html 感谢作者的分享 MySQL 的官网下载地址:http://www.mysql. ...

  4. oracle 日期

    http://blog.itpub.net/126211/viewspace-712986/

  5. hdu5387 Clock

    Problem Description Give a time.(hh:mm:ss).you should answer the angle between any two of the minute ...

  6. mysql中load data Infile运用

    速度比insert要快20倍.共享一下java程序操作. package com.mysql.csv; import java.sql.Connection; import java.sql.Driv ...

  7. css的三种表现形式

    1.行内样式(内嵌样式):结构的内部,即写在标签内的样式:写在标签的开始部分内部,style属性当中:<标记 style="样式的属性名1:样式的属性值1:属性名2:属性值2:.... ...

  8. VUE笔记 - 过滤器 Vue.filter 形参默认值 @keyup.f2 自定义按键修饰符

    过滤器函数的传参: 第一个参数 A 是固定的,表示要过滤之前的内容. 第二个参数 B,表示要把原本的内容 A 过滤成 B. 写函数内容时, 这里第二处只写个参数. 实际的值要写到管道符调用函数的括号内 ...

  9. Python中可避免读写乱码的一个强慷慨法

    昨天在帮同学解析一批从网络上爬取的文件时,遇到一个奇葩的问题,文件本身的编码是gbk,Eclipse编辑环境的默认编码是utf8,使用常规的open方法批量打开文件时,某些文件里存在一些不可被gbk识 ...

  10. uva 1463 - Largest Empty Circle on a Segment(二分+三分+几何)

    题目链接:uva 1463 - Largest Empty Circle on a Segment 二分半径,对于每一个半径,用三分求出线段到线段的最短距离,依据最短距离能够确定当前R下每条线段在[0 ...