loj #2026. 「JLOI / SHOI2016」成绩比较
#2026. 「JLOI / SHOI2016」成绩比较
题目描述
THU 的 G 系中有许许多多的大牛,比如小 R 的室友 B 神。B 神已经厌倦了与其他的同学比较 GPA(Grade Point Average,平均学分绩),他只在意 G 系中共有多少同学被他“碾压”。
B 神声称,在 G 系共有 kkk 位同学被他碾压。同是 G 系大牛的 D 神则认为 B 神在吹牛,他查到了 B 神每门必修课在 G 系的排名。他用了 173 毫秒的时间就计算出了有多少种情况使得 B 神所说的话成立。现在他想考考聪明的你,看你是否也能求出这个情况数。
G 系共有 nnn 位同学,mmm 门必修课。这 nnn 位同学的编号为 000 到 n−1n - 1n−1 的整数,其中 B 神的编号为 000 号。这 mmm 门必修课编号为 000 到 m−1m - 1m−1 的整数。如果在每门课上 A 获得的成绩均小于等于 B 获得的成绩,则称 A 被 B 碾压。在 B 神的说法中,G 系共有 kkk 位同学被碾压(不包括他自己),而其他 n−k−1n - k - 1n−k−1 名同学则没有被他碾压。
D 神查到了 B 神每门必修课的排名。这里的排名是指,如果 B 神某门课的排名为 rrr,则表示有且仅有 r−1r - 1r−1 位同学这门课的分数大于 B 神的分数,有且仅有 n−rn - rn−r 位同学这门课的分数小于等于 B 神(不包括他自己)。
我们需要求出全系所有同学每门必修课得分的情况数,使其既能满足 B 神的说法,也能符合 D 神查到的排名。这里两种情况不同当且仅当有任意一位同学在任意一门课上获得的分数不同。你不需要像 D 神那么厉害,你只需要计算出情况数模 109+710^9 + 7109+7 的余数就可以了。
输入格式
第一行包含三个正整数 n,m,kn, m, kn,m,k,分别表示 G 系的同学数量(包括 B 神)、必修课的数量和被 B 神碾压的同学数量。
第二行包含 mmm 个正整数,依次表示每门课的最高分 uiu_iui。
第三行包含 mmm 个正整数,依次表示 B 神在每门课上的排名 rir_iri。保证 1≤ri≤n1 \leq r_i \leq n1≤ri≤n。
数据保证至少有 111 种情况使得 B 神的描述成立。
输出格式
输出一行一个正整数,表示满足条件的情况数模 109+710^9 + 7109+7 的余数。
样例
样例输入 1
3 2 1
2 2
1 2
样例输出 1
10
样例说明 1
有且仅有以下 101010 种符合条件的情况:
# | B 神・课程 0 | B 神・课程 1 | 同学 A・课程 0 | 同学 A・课程 1 | 同学 B・课程 0 | 同学 B・课程 1 |
---|---|---|---|---|---|---|
1 | 1 | 1 | 1 | 1 | 1 | 2 |
2 | 1 | 1 | 1 | 2 | 1 | 1 |
3 | 2 | 1 | 1 | 1 | 1 | 2 |
4 | 2 | 1 | 1 | 1 | 2 | 2 |
5 | 2 | 1 | 1 | 2 | 1 | 1 |
6 | 2 | 1 | 1 | 2 | 2 | 1 |
7 | 2 | 1 | 2 | 1 | 1 | 2 |
8 | 2 | 1 | 2 | 1 | 2 | 2 |
9 | 2 | 1 | 2 | 2 | 1 | 1 |
10 | 2 | 1 | 2 | 2 | 2 | 1 |
样例输入 2
5 3 2
4 3 2
2 1 2
样例输出 2
54096
数据范围与提示
Case # | nnn | mmm | uiu_iui |
---|---|---|---|
1 | ≤3\leq 3≤3 | ≤3\leq 3≤3 | ≤4\leq 4≤4 |
2 | ≤3\leq 3≤3 | ≤10\leq 10≤10 | ≤100\leq 100≤100 |
3 | ≤3\leq 3≤3 | ≤100\leq 100≤100 | ≤109\leq 10^9≤109 |
4, 5 | ≤5\leq 5≤5 | ≤100\leq 100≤100 | ≤109\leq 10^9≤109 |
6, 7 | ≤50\leq 50≤50 | ≤50\leq 50≤50 | ≤50\leq 50≤50 |
8 ~ 10 | ≤100\leq 100≤100 | ≤100\leq 100≤100 | ≤109\leq 10^9≤109 |
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 110
#define mod 1000000007
using namespace std;
int n,m,K,u[maxn],r[maxn],ans,a[maxn][maxn];
bool check(){
int cnt,flag;
for(int i=;i<=m;i++){//枚举每门学科
cnt=;
for(int j=;j<=n;j++)
if(a[j][i]>a[][i])cnt++;
if(cnt!=r[i]-)return ;
}
cnt=;
for(int i=;i<=n;i++){
flag=;
for(int j=;j<=m;j++)
if(a[i][j]>a[][j]){flag=;break;}
if(flag==)cnt++;
}
if(cnt==K)return ;
else return ;
}
void dfs(int pos1,int pos2){
if(pos2==m+)pos1=pos1+,pos2=;
if(pos1==n+){ans+=check();return;}
for(int i=;i<=u[pos2];i++){
a[pos1][pos2]=i;
dfs(pos1,pos2+);
}
}
int main(){
freopen("Cola.txt","r",stdin);
scanf("%d%d%d",&n,&m,&K);
for(int i=;i<=m;i++)scanf("%d",&u[i]);
for(int i=;i<=m;i++)scanf("%d",&r[i]);
dfs(,);
printf("%d",ans);
}
10分 暴力
loj #2026. 「JLOI / SHOI2016」成绩比较的更多相关文章
- LOJ #2026「JLOI / SHOI2016」成绩比较
很好的锻炼推柿子能力的题目 LOJ #2026 题意 有$n$个人$ m$门学科,第$ i$门的分数为不大于$U_i$的一个正整数 定义A「打爆」B当且仅当A的每门学科的分数都不低于B的该门学科的分数 ...
- 【LOJ】#2026. 「JLOI / SHOI2016」成绩比较
题解 用\(f[i][j]\)表示考虑了前i个排名有j个人被碾压 \(f[i][j] = f[i - 1][k] \* C[k][j] \* C[N - k - 1][N - r[i] - j] \* ...
- loj #2024. 「JLOI / SHOI2016」侦查守卫
#2024. 「JLOI / SHOI2016」侦查守卫 题目描述 小 R 和 B 神正在玩一款游戏.这款游戏的地图由 nnn 个点和 n−1n - 1n−1 条无向边组成,每条无向边连接两个点, ...
- loj #2025. 「JLOI / SHOI2016」方
#2025. 「JLOI / SHOI2016」方 题目描述 上帝说,不要圆,要方,于是便有了这道题. 由于我们应该方,而且最好能够尽量方,所以上帝派我们来找正方形.上帝把我们派到了一个有 NNN ...
- loj2026 「JLOI / SHOI2016」成绩比较
orz #include <iostream> #include <cstdio> using namespace std; typedef long long ll; int ...
- 【LOJ】 #2025. 「JLOI / SHOI2016」方
题解 有什么LNOI啊,最后都是JLOI罢了 一道非常--懵逼的统计题 当然是容斥,所有的方案 - 至少有一个点坏掉的正方形 + 至少有两个点坏掉的正方形 - 至少有三个点坏掉的正方形 + 至少有四个 ...
- 【LOJ】#2024. 「JLOI / SHOI2016」侦查守卫
题解 童年的回忆! 想当初,这是我考的第一次省选,我当时初二,我什么都不会,然后看着这个东西,是不是能用我一个月前才会的求lca,光这个lca我就调了一个多小时= =,然后整场五个小时,我觉得其他题不 ...
- loj2024「JLOI / SHOI2016」侦查守卫
too hard #include <iostream> #include <cstdio> using namespace std; int n, d, m, uu, vv, ...
- Loj #2495. 「AHOI / HNOI2018」转盘
Loj #2495. 「AHOI / HNOI2018」转盘 题目描述 一次小 G 和小 H 原本准备去聚餐,但由于太麻烦了于是题面简化如下: 一个转盘上有摆成一圈的 \(n\) 个物品(编号 \(1 ...
随机推荐
- Java基础--序列化Serializable
对Java对象序列化的目的是持久化对象或者为RMI(远程方法调用)传递参数和返回值. 下面是一个序列化对象写入文件的例子: ---------------------------- package u ...
- Thread之四:java线程返回结果的方法
两种方式:一种继承Thread类实现:一种通过实现Callable接口. 第一种方法: 因为实现Thread类的run方法自身是没有返回值的,所以不能直接获得线程的执行结果,但是可以通过在run方法里 ...
- spring中JavaConfig相关的注解
在spring3.0中增加配置spring beans的新方式JavaConfig,可以替换spring的applicataion.xml配置.也即@Configuration对等<beans/ ...
- 环形缓冲区的应用ringbuffer
在嵌入式开发中离不开设备通信,而在通信中稳定性最高的莫过于环形缓冲区算法, 当读取速度大于写入速度时,在环形缓冲区的支持下不会丢掉任何一个字节(硬件问题除外). 在通信程序中,经常使用环形缓冲区作为数 ...
- PHP类(一)-类的实例化
类的实例化就是对象.一个类可以分成两个部分,一个是静态描述,就是类里的成员属性.第二个是动态描述,就是类里的成员方法,也就是对象的功能. 声明一个类,可以在class前加一些关键字,如abstract ...
- 2016.8.17服务器端数据库用户导入导出方法 expdp和impdp
EXP和IMP是客户端工具程序,它们既可以在客户端使用,也可以在服务端使用. EXPDP和IMPDP是服务端的工具程序,他们只能在ORACLE服务端使用,不能在客户端使用. IMP只适用于EXP导出的 ...
- scrapy-redis源码抛析
#scrapy-redis--->queue.py-->class FifoQueue 队列 LifoQueue(lastinfirstout栈) #self.server父类Base中链 ...
- Spring-@value用法详解
为了简化读取properties文件中的配置值,spring支持@value注解的方式来获取,这种方式大大简化了项目配置,提高业务中的灵活性. 一.两种使用方法 1.@Value("#{co ...
- 10-23C#基础--特殊集合(stack、queue、hashtable)
特殊集合一:stack集合--堆集合 1.定义:堆集合是集合中一种特殊的类,在Stack中也有许多方法和属性,下面一一列举: 命名格式:Stack ss=new Stack(); 2.如何添加数据:p ...
- 【275】◀▶ Python 控制语句说明
参考:Python循环语句 01 for 循环语句. 02 while 循环语句. 03 if...else 选择语句. 04 continue 执行循环语句中的下一条循环. 05 ...