poj2947Widget Factory
对于同余方程的高斯消元啊。
其实也差不多吧。先同一位通分,然后减一下就好了。
主要是判无解和多解的麻烦,需要注意即使有自由元也可能先无解
#include<cstdio>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<cmath> #define MOD(x) (x%7+7)%7
using namespace std; int n,m;
char ss[];
int scs()
{
scanf("%s",ss+);
if(ss[]=='M')return ;
else if(ss[]=='T'&&ss[]=='U')return ;
else if(ss[]=='W')return ;
else if(ss[]=='T')return ;
else if(ss[]=='F')return ;
else if(ss[]=='S'&&ss[]=='A')return ;
else return ;
} int gcd(int a,int b)
{
if(a==)return b;
return gcd(b%a,a);
}
int exgcd(int a,int b,int &x,int &y)
{
if(a==)
{
x=,y=;
return b;
}
else
{
int tx,ty;
int d=exgcd(b%a,a,tx,ty);
x=ty-b/a*tx;
y=tx;
return d;
}
} int qg[][],qc[];
int as[];
void gauss()
{
int j,jj;
for(j=,jj=;j<=n&&jj<=m;j++)
{
for(int i=jj;i<=m;i++)
if(qg[i][j]!=)
{
for(int k=j;k<=n;k++)swap(qg[i][k],qg[jj][k]);
swap(qc[i],qc[jj]);
break;
}
if(qg[jj][j]==)continue; for(int i=;i<=m;i++)
{
if(i==jj)continue; int gg=gcd(qg[i][j],qg[jj][j]);
int ml1=qg[jj][j]/gg,ml2=qg[i][j]/gg; for(int k=;k<=n;k++)
qg[i][k]=MOD(qg[i][k]*ml1-qg[jj][k]*ml2);
qc[i]=MOD(qc[i]*ml1-qc[jj]*ml2);
}
jj++;
}
for(int i=jj;i<=m;i++)
if(qc[i]>){printf("Inconsistent data.\n");return ;}
if(jj!=j||j<=n){printf("Multiple solutions.\n");return ;} for(int j=;j<=n;j++)
{
int A=qg[j][j],B=,K=qc[j],x,y;
int d=exgcd(A,B,x,y); x=(x*(K/d)%(B/d)+(B/d))%(B/d);
if(x<)x+=;
as[j]=x;
}
for(int j=;j<n;j++)printf("%d ",as[j]);
printf("%d\n",as[n]);
} int v[];
int main()
{
while(scanf("%d%d",&n,&m)!=EOF)
{
if(n==&&m==)break; for(int i=;i<=m;i++)
{
int k,x;
scanf("%d",&k);int s1=scs(),s2=scs();
qc[i]=MOD(s2-s1+); memset(v,,sizeof(v));
for(int j=;j<=k;j++)
scanf("%d",&x), v[x]++; for(int j=;j<=n;j++)qg[i][j]=MOD(v[j]);
} gauss();
}
return ;
}
poj2947Widget Factory的更多相关文章
- POJ2947Widget Factory(高斯消元解同模方程)
http://poj.org/problem?id=2947 题目大意:有n 种装饰物,m 个已知条件,每个已知条件的描述如下:p start enda1,a2......ap (1<=ai&l ...
- POJ2947-Widget Factory
工厂里每件期间的生产时间为3-9天,告诉你有N个器件和M个计划,每个计划都是说明生产1-N号器件的时间,最后问你每件器件的生产时间.或者多解或没有解. 例如样例 2 3 2 MON THU 1 2 3 ...
- PHP设计模式(三)抽象工厂模式(Abstract Factory For PHP)
一.什么是抽象工厂模式 抽象工厂模式的用意为:给客户端提供一个接口,可以创建多个产品族中的产品对象 ,而且使用抽象工厂模式还要满足以下条件: 系统中有多个产品族,而系统一次只可能消费其中一族产品. 同 ...
- PHP设计模式(一)简单工厂模式 (Simple Factory For PHP)
最近天气变化无常,身为程序猿的寡人!~终究难耐天气的挑战,病倒了,果然,程序猿还需多保养自己的身体,有句话这么说:一生只有两件事能报复你:不够努力的辜负和过度消耗身体的后患.话不多说,开始吧. 一.什 ...
- 菜鸟理解的工厂模式(Factory Pattern)是什么样子的?
直接开始说了,不浪费园友宝贵的时间! 什么是工厂模式? 在学习前,先问一下:"它是什么?". 工厂模式,它是项目里面常用的设计模式之一. 它是属于创建型模式,简单的理解创建型模式就 ...
- Angular Service和Factory应用的区别
Service可以用来将返回同类业务的多种返回值 Factory可以用来提供对同类业务的多个方法的调用 另外:Provider可以用来封装各独立职责
- 【解决方案】 org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'userHandler': Injection of resource dependencies failed;
一个错误会浪费好多青春绳命 鉴于此,为了不让大家也走弯路,分享解决方案. [错误代码提示] StandardWrapper.Throwableorg.springframework.beans.fac ...
- Design Patterns Simplified - Part 3 (Simple Factory)【设计模式简述--第三部分(简单工厂)】
原文链接:http://www.c-sharpcorner.com/UploadFile/19b1bd/design-patterns-simplified-part3-factory/ Design ...
- C#设计模式之简单工厂模式(Simple Factory)
1. 概述 简单工厂模式就是将一个类的实例化交给一个静态工厂来执行. 2. 使用频率 中 3. 模式结构 3.1 机构图 3.2 模式中的角色 Product:抽象类,把具体产品类公共的代码进行抽象和 ...
随机推荐
- BZOJ 4491 分块OR差分+线段树
思路: (是不是只有我作大死写了个分块) up[i][j]表示从第i块开始到第j个位置 上升的最大值 down[i][j]同理 left_up[i]表示从第i块开始能够上升的最长长度 left_dow ...
- 装饰模式(Decorator)C++实现
装饰模式 层层包装,增强功能.这就是装饰模式的要旨!装饰器模式就是基于对象组合的方式,可以很灵活的给对象添加所需要的功能.它把需要装饰的功能放在单独的类中,并让这个类包装它所要装饰的对象. 意图: 动 ...
- CSS简单入门
- Java攻城狮学习路线 - 一. 什么是CSS CSS指层叠样式表(Cascading Style Sheets),定义如何显示HTML元素 二. CSS语法 /* 选择器 { 声明: 声明:}* ...
- mvc关于pots请求 哪个函数 出现bug研究
这样能请求home下的updateA函数 这样能请求home下的update函数,不能请求updateA函数
- 【转】ORACLE SQL基础—DDL语言 礼记八目 2017-12-23 21:26:21
原文地址:https://www.toutiao.com/i6502733303550837261/ SQL语言分为:DDL数据定义语言,DML数据操纵语言,DCL是数据库控制语言,TC事务控制语言 ...
- 【udacity】机器学习-波士顿房价预测小结
Evernote Export 机器学习的运行步骤 1.导入数据 没什么注意的,成功导入数据集就可以了,打印看下数据的标准格式就行 用个info和describe 2.分析数据 这里要详细分析数据的内 ...
- hibernate注解--@transient
@transient:表示该属性并非一个到数据库表的字段的映射,ORM框架将忽略该属性. 如果一个属性并非数据库表的字段映射,就务必将其标示为@Transient,否则,ORM框架默认其注解为@Bas ...
- python指定日期后加几天判断
#!/usr/bin/python import datetime import sys arg1_list=list(sys.argv[1].split(',')) arg2_list=list(s ...
- git入坑随笔
一直以来,都喜欢用git做版本管理,主要涉及平台是coding, github以及公司自己搭建的gitlab. 因为一直以来都是自己一个人维护前端的项目,所以基本上很少有冲突的情况.(手动微笑 :) ...
- WEBGL学习【十三】鼠标点击立方体改变颜色的原理与实现
// PickFace.js (c) 2012 matsuda and kanda // Vertex shader program var VSHADER_SOURCE = 'attribute v ...