Time Limit: 1 second

Memory Limit: 128 MB

【问题描述】

找到一个数组的最大值的一种方法是从数组开头从前到后对数组进行扫描,令max=a[0](数组下表从0..N-1),如果a[i]>max,就更新max,这样

就可以在O(N)的时间里找到一个数组的最大值。

这个问题是相当简单的,但是想到了另一个问题,如果一个包含N个元素的数组a里面的元素的值是在1...K之间的整数,存在多少个不同的数组

a,进行了如上扫描之后,max恰好进行了p次更新? 

下面是N = 4,K = 3,P = 2时所有情况

1) {1,1,2,3}

2) {1,2,1,3}

3) {1,2,2,3}

4) {1,2,3,1}

5) {1,2,3,2}

6) {1,2,3,3}

共有6种情况

由于答案可能很大,所以你仅仅需要把答案mod 10^9+7输出。

【输入格式】

输入文件findmax.in的第一行T,本题有T组数据。 接下来T行,每行三个整数,N,K,P

【输出格式】

输出文件findmax.out包括T行,每行一个答案。

【数据规模】

30%数据 T=1 1 <= n <= 10 1 <= K <= 2 0 <= P < n 60%数据 T=1 1 <= n <= 50 1 <= K <= 10 0 <= P < n 100%数据 1 <= T <= 100 1 <= n <= 100 1 <= K <= 300 0 <= P < n

Sample Input1

3
4 3 2
2 3 1
3 4 1

Sample Output1

6
3
30
【题解】
设f[n][k][p]表示序列长度为n,最大值为k,要更新p次这样的序列个数。
f[n][k][p] = f[n - 1][k][p] * k + ∑(f[n - 1][0..k - 1][p - 1]);
前面一个表示在序列长度为n - 1,最大值为k,更新过p次的序列后面加上1..k这些数字。因为不会再更
新所以转移的方式是对的。
后面一个求和则表示在长度为n - 1, 最大值在0..k - 1之间,然后更新过p - 1次, 在后面加上一个k就
会更新p次了。然后最大值也变成了k.
然后那个求和部分可以不用每次都算一次。可以累加然后加上去。不然会超时。
然后一开始预处理出f[1..100][0..300][1..100]。然后对于每一个输入n,k,p
输出∑(f[n][p+1..k][p]);
【代码】
#include <cstdio>
#include <cstring>
#include <iostream> const int mo = 1000000007; long long f[101][301][101];
int n, k, p; void input_data()
{
scanf("%d%d%d", &n, &k, &p);
} void get_ans()
{
memset(f, 0, sizeof(f));
for (int j = 1; j <= 300; j++)//要处理出只有一个元素的情况。不然从f[0][0][0]递推到f[1][1..k][1]会出错。
//因为f[1][1..k][1]是不可能出现的。因为只有一个元素。它是没有被更新过的。
f[1][j][0] = 1;
for (int i = 2; i <= 100; i++) //大于等于2之后则用递推的方式递推出所有f值
for (int m = 0; m <= 100; m++)
{
int leijia = 0; //累加和。不要每次都算求和的值。
for (int j = 1; j <= 300; j++)
{
f[i][j][m] = (f[i][j][m] + f[i - 1][j][m] * j) % mo; //这是不更新的情况 不用累加。
leijia = (leijia + f[i - 1][j - 1][m - 1]) % mo; //这是要更新的情况。在末尾加上一个j就可以了。
if (m != 0) //m-1在m!=0的时候才要访问。
f[i][j][m] = (f[i][j][m] + leijia) % mo;
}
}
} void output_ans()
{
int ans = 0;
for (int i = p + 1; i <= k; i++) //输出∑(f[n][p+1..k][p])
ans = (ans + f[n][i][p]) % mo;
printf("%d\n", ans);
} int main()
{
get_ans();//先预处理出f[1..100][0..300][1..100]
int t;
scanf("%d", &t);//输入t
for (int kk = 1; kk <= t; kk++) //输入t组数据然后直接输出相应的答案。
{
input_data();
output_ans();
}
return 0;
}

【U205】最大值的更多相关文章

  1. C语言 · 最大值与最小值计算

    输入11个整数,计算它们的最大值和最小值. 样例输入 0 1 2 3 4 5 6 7 8 9 10 样例输出 10 0   #include<stdio.h> int main(){ ]; ...

  2. [LeetCode] Split Array Largest Sum 分割数组的最大值

    Given an array which consists of non-negative integers and an integer m, you can split the array int ...

  3. [LeetCode] Sliding Window Maximum 滑动窗口最大值

    Given an array nums, there is a sliding window of size k which is moving from the very left of the a ...

  4. 整理:Javascript获取数组中的最大值和最小值的方法汇总

    方法一: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 //最小值 Array.prototype.min = function ...

  5. HDU 1754 I Hate It 线段树单点更新求最大值

    题目链接 线段树入门题,线段树单点更新求最大值问题. #include <iostream> #include <cstdio> #include <cmath> ...

  6. Poj The xor-longest Path 经典题 Trie求n个数中任意两个异或最大值

    Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 5646   Accepted: 1226 Description In an ...

  7. 不需要sql进行计算数据的平均值、最大值、最小值、和

    介绍下SqlServer.前端js.后台C#三个阶段对均值.最大值.最小值.和计算int[] jisuan = {0, 1, 3, 5, 7,8 }; List<int> jisuan2 ...

  8. 在一个SQL Server表中的多个列找出最大值

    在一个SQL Server表中一行的多个列找出最大值 有时候我们需要从多个相同的列里(这些列的数据类型相同)找出最大的那个值,并显示 这里给出一个例子 IF (OBJECT_ID('tempdb..# ...

  9. C语言 · 寻找数组中的最大值

    问题描述 对于给定整数数组a[],寻找其中最大值,并返回下标. 输入格式 整数数组a[],数组元素个数小于1等于100.输出数据分作两行:第一行只有一个数,表示数组元素个数:第二行为数组的各个元素. ...

随机推荐

  1. POJ——T 1006 Biorhythms

    http://poj.org/problem?id=1006 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 138219   ...

  2. 用c实现的各种排序的方法

    #include <stdio.h> void swap(int *a, int *b); void bubble_sort(int a[], int n); void select_so ...

  3. Xamarin开发手机聊天程序

    使用Xamarin开发手机聊天程序 -- 基础篇(大量图文讲解 step by step,附源码下载)   如果是.NET开发人员,想学习手机应用开发(Android和iOS),Xamarin 无疑是 ...

  4. PatentTips - Resource partitioning and direct access utilizing hardware support for virtualization

    BACKGROUND The present disclosure relates to the resource management of virtual machine(s) using har ...

  5. 芯片AMS1117 电源芯片

  6. GO语言学习(七)Go 语言变量

    Go 语言变量 变量来源于数学,是计算机语言中能储存计算结果或能表示值抽象概念.变量可以通过变量名访问. Go 语言变量名由字母.数字.下划线组成,其中首个字母不能为数字. 声明变量的一般形式是使用 ...

  7. Linux下开启关闭防火墙

    一.Linux下开启/关闭防火墙命令 1) 永久性生效,重启后不会复原 开启: chkconfig iptables on 关闭: chkconfig iptables off   2) 即时生效,重 ...

  8. Nginx- 实现跨域访问

    https://blog.csdn.net/m_nanle_xiaobudiu/article/details/80688740

  9. [Angular] Implementing A General Communication Mechanism For Directive Interaction

    We have modal implement and now we want to implement close functionality. Becuase we use a structure ...

  10. MongoDB 管理

    1.给数据库增加分片功能 mongos> use admin mongos> db.runCommand({enablesharding:"cipnet"}) mong ...