这个应该是第一场有英文的atcoder吧??不过题解却没有英文的。。。

从前往后慢慢做。。。

C こだわり者いろはちゃん / Iroha's Obsession

数据范围这么小,直接暴力

#include <bits/stdc++.h>
using namespace std; bool rec[10]; bool check(int num)
{
while(num)
{
if(rec[num%10]) return false;
num /= 10;
}
return true;
} int main()
{
int n,k,num;
cin >> n >> k;
for(int i = 0; i < k; ++i)
{
cin >> num;
rec[num] = true;
} while(true)
{
if(check(n))
{
cout << n << endl;
break;
}
++n;
}
return 0;
}

####D - いろはちゃんとマス目 / Iroha and a Grid
在H * W的矩阵中,左下角有一个A * B的矩阵不能走,求左上角走到右下角方法数。
建议一道题: 51nod 1486 大大走格子
这题容斥原理,比上边那个题简单。没有障碍时,总方法数是C(H+W-2,H-1)总方法数
求出来所有走过障碍处的走法, 用总的减掉就好了。
走过障碍处的方法数就是走到A*B矩阵上方一行的时候,选择向下走,就是非法的。减掉这些就好。
```
#include
using namespace std;
typedef long long LL;
const int MAXN = 100010;
const LL mod = 1e9+7;
typedef long long LL;
LL H,W,A,B;
LL fac[MAXN*2],inv[MAXN*2];

LL modPow(LL a, LL b)

{

LL ret = 1;

while(b)

{

if(b&1) ret = reta%mod;

a = a
a%mod;

b >>= 1;

}

return ret;

}

void init()

{

fac[0] = 1;

inv[0] = 1;

for(LL i = 1; i <= H+W; ++i)

fac[i] = fac[i-1]i%mod;

inv[H+W] = modPow(fac[H+W],mod-2);

for(LL i = H+W-1; i >= 1; --i)

inv[i] = (inv[i+1]
(i+1))%mod;

}

LL C(LL n, LL m)

{

LL ret = (fac[n]inv[m]%mod)inv[n-m]%mod;

return ret;

}

int main()

{

cin >> H >> W >> A >> B;

init();

LL res = C(H+W-2,H-1);

LL minu = 0;

for(int i = 1; i <= B; ++i)

minu = (minu + C(H-A+i-2, H-A-1)*C(A+W-i+1-2,A-1)%mod)%mod;

cout << ((res-minu)%mod+mod)%mod << endl;

return 0;

}

<hr/>
####E - 和風いろはちゃん / Iroha and Haiku
没有找到英文题解和中文题解。。。。。
这个题,感觉有点难。起初思路是算组合数,毕竟数据范围很小,算出1-7的拆分数的每种情况,然后算组合数和排列呗。
算了好久,不知道哪里错了,看了http://imulan.hatenablog.jp/entry/2016/07/24/233524这个题解,才发现有地方重复计算了。
然后又看了https://kimiyuki.net/blog/2016/07/23/arc-058-e/这个题解,还有官方题解,理解的模模糊糊。
比如说1用1表示,2用10表示,3用100表示,即i用(1<<(i-1))表示。
在这里是计算出不合法的数量,总数量-不合法数量=结果。
比如说要的X,Y,Z是5,7,5,表示这个结果的状态就是10000100000010000。
然后枚举每种情况。。。
还是有点懵。。。路过的大佬求解答。。
感觉日语翻译成英语比翻译成汉语读着顺一点。。

include

include

include

typedef long long ll;

using namespace std;

const int mod = 1e9+7;

ll dp[41][1<<18];

int main()

{

int n, x, y, z;

scanf("%d%d%d%d", &n, &x, &y, &z);

int l = x+y+z-1;

int mask = (1<<l)-1;

int limit = (1<<l);

int ok = (1 << (x+y+z-1)) | (1 << (y+z-1)) | (1 << (z-1));

dp[0][0] = 1;

for(int i = 0; i < n; ++i)

{

for(int s = 0; s < limit; ++s)

{

for(int a = 1; a < 11; ++a)

{

int t = (s << a) | (1 << (a-1));

if ((ok&t) == ok) continue;

//旧的状态向新的状态转移

(dp[i+1][t & mask] += dp[i][s]) %= mod;

}

}

}

ll ans = 1;

for(int i = 0; i < n; ++i)

ans = ans * 10 % mod;

//去掉每种状态的不合法数量

for(int s = 0; s < limit; ++s)

ans -= dp[n][s];

ans = (ans % mod + mod) % mod;
printf("%lld\n", ans);
return 0;

}

<hr/>
####F - 文字列大好きいろはちゃん / Iroha Loves Strings
------不会

AtCoder Regular Contest 058的更多相关文章

  1. Atcoder Regular Contest 058 D - 文字列大好きいろはちゃん / Iroha Loves Strings(单调栈+Z 函数)

    洛谷题面传送门 & Atcoder 题面传送门 神仙题. mol 一发现场(bushi)独立切掉此题的 ycx %%%%%%% 首先咱们可以想到一个非常 naive 的 DP,\(dp_{i, ...

  2. AtCoder Regular Contest 061

    AtCoder Regular Contest 061 C.Many Formulas 题意 给长度不超过\(10\)且由\(0\)到\(9\)数字组成的串S. 可以在两数字间放\(+\)号. 求所有 ...

  3. AtCoder Regular Contest 094 (ARC094) CDE题解

    原文链接http://www.cnblogs.com/zhouzhendong/p/8735114.html $AtCoder\ Regular\ Contest\ 094(ARC094)\ CDE$ ...

  4. AtCoder Regular Contest 092

    AtCoder Regular Contest 092 C - 2D Plane 2N Points 题意: 二维平面上给了\(2N\)个点,其中\(N\)个是\(A\)类点,\(N\)个是\(B\) ...

  5. AtCoder Regular Contest 093

    AtCoder Regular Contest 093 C - Traveling Plan 题意: 给定n个点,求出删去i号点时,按顺序从起点到一号点走到n号点最后回到起点所走的路程是多少. \(n ...

  6. AtCoder Regular Contest 094

    AtCoder Regular Contest 094 C - Same Integers 题意: 给定\(a,b,c\)三个数,可以进行两个操作:1.把一个数+2:2.把任意两个数+1.求最少需要几 ...

  7. AtCoder Regular Contest 095

    AtCoder Regular Contest 095 C - Many Medians 题意: 给出n个数,求出去掉第i个数之后所有数的中位数,保证n是偶数. \(n\le 200000\) 分析: ...

  8. AtCoder Regular Contest 102

    AtCoder Regular Contest 102 C - Triangular Relationship 题意: 给出n,k求有多少个不大于n的三元组,使其中两两数字的和都是k的倍数,数字可以重 ...

  9. AtCoder Regular Contest 096

    AtCoder Regular Contest 096 C - Many Medians 题意: 有A,B两种匹萨和三种购买方案,买一个A,买一个B,买半个A和半个B,花费分别为a,b,c. 求买X个 ...

随机推荐

  1. java知识点---文件分隔符

    本篇讲述java编程中,怎样解决跨平台时,因不同系统中分隔符不同导致的文件或路径找不到的问题 首先来看两个例子: 一.linux系统和windows系统中的文件路径: Linux系统: Windows ...

  2. CentOS 7 yum 安装与配置MySQL5.7

    1.下载mysql源安装包 wget http://dev.mysql.com/get/mysql57-community-release-el7-8.noarch.rpm 2.安装mysql源 yu ...

  3. Linux监听的网络服务$ netstat -ntlp$ netstat -nulp$ netstat -nxlp

    我一般都分开运行这三个命令,不想一下子看到列出一大堆所有的服务.netstat -nalp倒也可以.不过我绝不会用 numeric 选项 (鄙人一点浅薄的看法:IP 地址看起来更方便). 找到所有正在 ...

  4. 【模板】tyvjP1520 树的直径 [2017年5月计划 清北学堂51精英班Day3]

    P1520 树的直径 时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 树的直径,即这棵树中距离最远的两个结点的距离.每两个相邻的结点的距离为1,即父亲结点与儿 ...

  5. 未加星标 ajax三级联动的实现方法

    <div id="sanji"></div> 下面考虑的是要有省市区这三列,这三列用的是下拉列表,那么里面要用<option></opti ...

  6. 用 Python 写一个 NoSQL 数据库Python

    NoSQL 这个词在近些年正变得随处可见. 但是到底 “NoSQL” 指的是什么? 它是如何并且为什么这么有用? 在本文, 我们将会通过纯 Python (我比较喜欢叫它, “轻结构化的伪代码”) 写 ...

  7. poj 2001 Shortest Prefixes(字典树trie 动态分配内存)

    Shortest Prefixes Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 15610   Accepted: 673 ...

  8. 【django后端分离】Django Rest Framework之认证系统之redis数据库的token认证(token过期时间)

    1:登录视图 redis_cli.py文件: import redis Pool= redis.ConnectionPool(host='localhost',port=6379,decode_res ...

  9. 每日算法之三十四:Multiply Strings

    大数相乘,分别都是用字符串表示的两个大数.求相乘之后的结果表示. 首先我们应该考虑一下測试用例会有哪些,先准备測试用例对防御性编程会有比較大的帮助.可以考虑一些极端情况.有以下几种用例: 1)&quo ...

  10. SDUT-3402_数据结构实验之排序五:归并求逆序数

    数据结构实验之排序五:归并求逆序数 Time Limit: 50 ms Memory Limit: 65536 KiB Problem Description 对于数列a1,a2,a3-中的任意两个数 ...