码迷,mamicode.com
首页 > 其他好文 > 详细

【题解】幸运数列

时间:2019-04-06 14:10:14      阅读:121      评论:0      收藏:0      [点我收藏+]

标签:data-   turn   cin   alt   选择   spl   splay   ret   stream   

题目描述

        幸运数列是指该数列的每一个数都至少是它前面的数的两倍。假设数列的元素个数是N,元素的值范围是从1到M,当N=4,M=10时,可以生成下面4个幸运数列:

        1 2 4 8

        1 2 4 9

        1 2 4 10

        1 2 5 10

        给定N和M,你的任务是算出有多少个幸运数列可供选择。

 

输入输出格式

输入格式

        一行,按照N和M的顺序排列且满足1≤N≤10, 1≤M≤1000,N和M被一个空格分隔。

 

输出格式

        一行,只需输出数对N和M所产生的幸运数列的个数。

 

输入输出样例

输入样例

4 10

 

输出样例

4

 

题解

         直接推即可,前缀和优化可以更快。

技术图片
#include <iostream>

#define MAX_N (10 + 5)
#define MAX_M (1000 + 5)

using namespace std;

int n, m;
int a[MAX_N][MAX_M];

int main()
{
    cin >> n >> m;
    if((1 << n - 1) > m) return cout << 0, 0;
    int r = m >> n - 1;
    for(register int i = 1; i <= m; ++i)
    {
        a[1][i] = i;
    }
    for(register int i = 2; i <= n; ++i)
    {
        r <<= 1;
        for(register int j = 1 << i - 1; j <= m; ++j)
        {
            a[i][j] = a[i - 1][j >> 1] + a[i][j - 1];
        }
    }
    cout << a[n][m];
    return 0;
}
参考程序

 

【题解】幸运数列

标签:data-   turn   cin   alt   选择   spl   splay   ret   stream   

原文地址:https://www.cnblogs.com/kcn999/p/10661513.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!