前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >2431: [HAOI2009]逆序对数列

2431: [HAOI2009]逆序对数列

作者头像
HansBug
发布2018-04-10 16:24:38
6910
发布2018-04-10 16:24:38
举报
文章被收录于专栏:HansBug's LabHansBug's Lab

2431: [HAOI2009]逆序对数列

Time Limit: 5 Sec  Memory Limit: 128 MB

Submit: 954  Solved: 548

[Submit][Status]

Description

对于一个数列{ai},如果有i<j且ai>aj,那么我们称ai与aj为一对逆序对数。若对于任意一个由1~n自然数组成的数列,可以很容易求出有多少个逆序对数。那么逆序对数为k的这样自然数数列到底有多少个?

Input

 第一行为两个整数n,k。

Output

写入一个整数,表示符合条件的数列个数,由于这个数可能很大,你只需输出该数对10000求余数后的结果。

Sample Input

样例输入 4 1

Sample Output

样例输出 3 样例说明: 下列3个数列逆序对数都为1;分别是1 2 4 3 ;1 3 2 4 ;2 1 3 4; 测试数据范围 30%的数据 n<=12 100%的数据 n<=1000,k<=1000

HINT

Source

Day1

题解:乍一看看到逆序对个数这样的字眼,还有些小激动呢,再一看,居然是个DP(Phile:呵呵 HansBug:TT)——这个嘛,递推式也很明显——f[i,j]:=f[i-1,1]+f[i-1,2]+f[i-1,3]....+f[i-1,j],所以直接求吧(注注注注注意:记得%10000,还有%10000时先加个10000以防万一)

代码语言:javascript
复制
 1 var
 2    i,j,k,l,m,n:longint;
 3    a:array[0..2000,0..2000] of longint;
 4 begin
 5      readln(n,m);
 6      fillchar(a,sizeof(a),0);
 7      for i:=1 to n do
 8          a[i,0]:=1;
 9      for i:=2 to n do
10          begin
11               l:=a[i-1,0];
12               for j:=1 to m do
13                   begin
14                        if not(j<i) then l:=l-a[i-1,j-i];
15                        l:=l+a[i-1,j];
16                        a[i,j]:=(l+20000) mod 10000;
17                   end;
18          end;
19      writeln(a[n,m]);
20 end.          
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2014-12-21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 2431: [HAOI2009]逆序对数列
  • Description
  • Input
  • Output
  • Sample Input
  • Sample Output
  • HINT
  • Source
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档