您的位置:首页 > 其它

XDU 1036-神奇的盒子

2013-12-18 18:24 169 查看
Problem 1036 - 神奇的盒子
Time Limit: 1000MS Memory Limit: 65536KB Difficulty:

Total Submit: 318 Accepted: 141 Special Judge: No

Description

  WM平时喜欢在夜晚游历于花丛、土堆等新校区隐蔽的角落,因为他觉得那样可以见到某些平时见不到的东西,找到某些比较稀奇的物品。随着其长期的寻觅,他终于找到了一个外表精美但上了锁的盒子,盒子没有锁眼,只有刻在上面的3对半数字:(1,1)、(4,5)、(7,15)和那个独立的数字100。

WM将盒子带回实验室,和ZYF一起研究,经过商议与复杂的推算,他们认定这些以(x,y)形式出现的数值就是传说中的拆分数(即将x变为一系列数连加,而不同的加法式子的数目就是其拆分数y),只要得到100的拆分数就能打开这个盒子。

例如,对于3,其不同的连加式有3个,即:3 = 1 + 1 + 1,3 = 1 + 2,3 = 3。式子1 + 2与式子2 + 1视为相同的式子。

WM和ZYF决定编写一个程序来计算给定正整数的拆分数,从而可以打开这个盒子,看看里头到底有什么秘密。

Input

输入数据的第一行是一个正整数T(1≤T≤100),表示有T组待测数据,每组待测数据占一行,是一个正整数N(1≤N≤100)。

Output

对于每组输入数据,输出一个整数表示N的拆分数,输出每个整数后换行。

Sample Input

3

1

4

7

Sample Output

1

5

15

Hint

Source

8th Xidian University Collegiate Programming Contest(2010.6)









#include<stdio.h>
int main()
{
     int f[101][101], i, j;
     for(i = 1; i <= 100; i++)
     f[i][1] = f[1][i] = 1;
     for(i = 2; i <= 100; i++)
     {
        for(j = 2; j <= 100; j++)
        {
            if(j>i)
                f[i][j]=f[i][i];
            else if(j==i)
                f[i][j]=1+f[i][j-1];
            else
                f[i][j]=f[i-j][j]+f[i][j-1];
        }
     }
     int T,m;
     scanf("%d",&T);
     while(T--)
     {
         scanf("%d", &m);
         printf("%d\n",f[m][m]);
     }
     return 0;
}




分析看这儿
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: