[BZOJ 4563]放棋子

题目

给你一个N*N的矩阵,每行有一个障碍,数据保证任意两个障碍不在同一行,任意两个障碍不在同一列,要求你在这个矩阵上放N枚棋子(障碍的位置不能放棋子),要求你放N个棋子也满足每行只有一枚棋子,每列只有一枚棋子的限制,求有多少种方案。

INPUT

第一行一个N,接下来一个N*N的矩阵。N<=200,0表示没有障碍,1表示有障碍,输入格式参考样例

OUTPUT

一个整数,即合法的方案数。

SAMPLE

INPUT

2
0 1
1 0

OUTPUT

1

解题报告

一道读入都不用打完的题= =

只用读入$n$就好了QAQ

全错位排列往上一打,加个高精就好了QAQ

 #include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
struct bign{
int a[],len;
bign():len(){memset(a,,sizeof(a));}
bign(const char *s){*this=s;}
bign(const int &x){*this=x;}
inline void operator=(const char *s){
len=strlen(s);
for(int i=;i<len;++i)
a[i]=s[len-i-]-'';
}
inline void operator=(const int &x){
char s[];
memset(s,,sizeof(s));
sprintf(s,"%d",x);
*this=s;
}
inline void clear(){while(len>&&!a[len-])--len;}
inline bign operator+(const bign &x){
bign ret;
ret.len=max(len,x.len)+;
int jw();
for(int i=;i<len;++i){
ret.a[i]=a[i]+x.a[i]+jw;
jw=ret.a[i]/;
ret.a[i]%=;
}
if(jw)
ret.a[len++]=jw;
ret.clear();
return ret;
}
inline void operator+=(const bign &x){*this=*this+x;}
inline bign operator-(const bign &x){
bign ret;
ret=*this;
for(int i=;i<len;++i){
if(ret.a[i]<x.a[i])
ret.a[i]+=,--ret.a[i+];
ret.a[i]=ret.a[i]-x.a[i];
}
ret.clear();
return ret;
}
inline void operator-=(const bign &x){*this=*this-x;}
inline bign operator-(const int &x){
bign tmp(x);
return *this-tmp;
}
inline void operator-=(const int &x){*this=*this-x;}
inline bign operator*(const bign &x){
bign ret;
ret.len=len+x.len+;
int jw;
for(int i=;i<len;++i){
jw=;
for(int j=;j<x.len;++j){
ret.a[i+j]+=a[i]*x.a[j]+jw;
jw=ret.a[i+j]/;
ret.a[i+j]%=;
}
ret.a[i+x.len]+=jw;
}
ret.clear();
return ret;
}
inline void operator*=(const bign &x){*this=*this*x;}
inline bign operator*(const int &x){
bign tmp(x);
return *this*tmp;
}
inline void operator*=(const int &x){*this=*this*x;}
inline void print(){
for(int i=len-;i>=;--i)
printf("%d",a[i]);
}
}f[];
int n;
int main(){
scanf("%d",&n);
f[]=;
f[]=;
for(int i=;i<=n;++i)
f[i]=(f[i-]+f[i-])*(i-);
f[n].print();
}

[BZOJ 4563]放棋子的更多相关文章

  1. BZOJ 4563: [Haoi2016]放棋子

    Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 389  Solved: 248[Submit][Status][Discuss] Descriptio ...

  2. BZOJ——T 4563: [Haoi2016]放棋子

    Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 387  Solved: 247[Submit][Status][Discuss] Descriptio ...

  3. BZOJ 3294: [Cqoi2011]放棋子

    3294: [Cqoi2011]放棋子 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 628  Solved: 238[Submit][Status] ...

  4. bzoj千题计划261:bzoj3294: [Cqoi2011]放棋子

    http://www.lydsy.com/JudgeOnline/problem.php?id=3294 如果一个颜色的棋子放在了第i行第j列,那这种颜色就会占据第i行第j列,其他颜色不能往这儿放 设 ...

  5. 【BZOJ 3294】 3294: [Cqoi2011]放棋子 (DP+组合数学+容斥原理)

    3294: [Cqoi2011]放棋子 Description Input 输入第一行为两个整数n, m, c,即行数.列数和棋子的颜色数.第二行包含c个正整数,即每个颜色的棋子数.所有颜色的棋子总数 ...

  6. 【BZOJ3294】放棋子(动态规划,容斥,组合数学)

    [BZOJ3294]放棋子(动态规划,容斥,组合数学) 题面 BZOJ 洛谷 题解 如果某一行某一列被某一种颜色给占了,那么在考虑其他行的时候可以直接把这些行和这些列给丢掉. 那么我们就可以写出一个\ ...

  7. BZOJ4563:[HAOI2016]放棋子——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=4563 给你一个N*N的矩阵,每行有一个障碍,数据保证任意两个障碍不在同一行,任意两个障碍不在同一列 ...

  8. bzoj4563: [Haoi2016]放棋子(错排+高精)

    4563: [Haoi2016]放棋子 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 387  Solved: 247[Submit][Status] ...

  9. [Haoi2016]放棋子 题解

    4563: [Haoi2016]放棋子 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 440  Solved: 285[Submit][Status] ...

随机推荐

  1. hdu 4587(枚举+割顶)

    TWO NODES Time Limit: 24000/12000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total ...

  2. [BZOJ 2006] 狼抓兔子

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=1001 [算法] 最小割 [代码] #include<bits/stdc++.h ...

  3. 洛谷P2303 [SDOi2012]Longge的问题

    题目背景 SDOi2012 题目描述 Longge的数学成绩非常好,并且他非常乐于挑战高难度的数学问题.现在问题来了:给定一个整数N,你需要求出∑gcd(i, N)(1<=i <=N). ...

  4. java事件处理机制(自定义事件)

    java中的事件机制的参与者有3种角色: 1.event object:事件状态对象,用于listener的相应的方法之中,作为参数,一般存在与listerner的方法之中 2.event sourc ...

  5. c3p0-config.xml文件简单说明与备忘

    <?xml version="1.0" encoding="UTF-8"?> <c3p0-config> <named-confi ...

  6. css样式之vertical-align垂直居中的应用

    css样式之vertical-align垂直居中的应用:将图片垂直左右居中 元素垂直居中 1:必须给容器父元素加上text-align:center 2:必须给当前元素转换成行内块元素,display ...

  7. js mvc框架

    介绍 使用过 JavaScript框架(如 AngularJS, Backbone 或者Ember)的人都很熟悉在UI(用户界面,前端)中mvc的工作机理.这些框架实现了MVC,使得在一个单页面中实现 ...

  8. 自定义View(8)关于measure->onMeasur->setMeasuredDimension及getDefaultSize,resolveSizeAndState

    参考: http://www.cnblogs.com/xiaorenwu702/p/5185436.html 当外层容器组件调用其内部的某个组件view1.measure(xxx)时,view1的on ...

  9. SVN系列学习(一)-SVN的安装与配置

    1.SVN的介绍 SVN是Subversion的简称,是一个开发源代码的版本控制系统,采用了分支管理系统. 文件保存在中央版本库,除了能记住文件和目录的每次修改以外,版本库非常像普通的文件服务器.你可 ...

  10. 【java基础】java中重载与重写的区别

    重载(Overloading) (1) 方法重载是让类以统一的方式处理不同类型数据的一种手段.多个同名函数同时存在,具有不同的参数个数/类型.重载Overloading是一个类中多态性的一种表现. ( ...