| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 946 人关注过本帖
标题:论坛高手瞧一瞧~有题目求交流。
只看楼主 加入收藏
q7408695
Rank: 2
等 级:论坛游民
帖 子:22
专家分:50
注 册:2011-8-2
结帖率:0
收藏
已结贴  问题点数:20 回复次数:11 
论坛高手瞧一瞧~有题目求交流。
看到论坛好冷清啊。想认识论坛的高手。都冒出来吧。

特地找了几个数学题目大家来一起交流哈

题目:一个人需要上到一个n级的楼梯顶端。
         现在他单次可以踏上一级或者两级。
         
   1.请求出他到达顶端的可行方案总数。
   2.请穷举出他到达顶端的所有可行方案。
   3.若他单词可以踏上1 2 3...k级。求2。
   4.若他单次可以踏上m m+1 m+2...k级。求2。
   5.若单次可以踏上a b c ...这些值由用户输入。求2。
  
附上第3问我写出来的,呵呵。
上楼梯2.0.zip (35.27 KB)



[ 本帖最后由 q7408695 于 2011-8-9 17:36 编辑 ]
搜索更多相关主题的帖子: 用户 一个人 数学 
2011-08-09 17:31
q7408695
Rank: 2
等 级:论坛游民
帖 子:22
专家分:50
注 册:2011-8-2
收藏
得分:0 
自己顶一下。

[ 本帖最后由 q7408695 于 2011-8-9 17:34 编辑 ]
2011-08-09 17:32
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:7 
第一问  斐波那契数列只不过 f(1) = 1 f(2) = 2
程序代码:
#include<stdio.h>
#define MAX 65
__int64 mem[MAX] = {0};
int main()
{
    int n = 0;
    mem[1] = 1;mem[2] = 2;
    for(int i = 3;i<MAX;i++)
    {
        mem[i] = mem[i-1]+mem[i-2];
    }
    while(EOF != scanf("%d",&n))
    {
        printf("%I64d\n",mem[n]);
    }
}

敢问楼主第二问要怎么穷举呢  如果n很大 它的解空间将会是一颗非常庞大的二叉树

只要从根开始累加到大于n的都将是一条可行的递归路径  已经写出来了  回溯法加剪枝


[ 本帖最后由 laoyang103 于 2011-8-9 18:11 编辑 ]

                                         
===========深入<----------------->浅出============
2011-08-09 17:41
q7408695
Rank: 2
等 级:论坛游民
帖 子:22
专家分:50
注 册:2011-8-2
收藏
得分:0 
回复 3楼 laoyang103
嘿嘿,先热身呗。
2011-08-09 17:53
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
程序代码:
#include<stdio.h>
#define MAX 65
void fun(int d,int sum,int mem[],int depth,int n)//走几步 只有1 2,当前走的总步数,存储步数,递归深度,走几层
{
    if(sum > n)//剪枝
        return ;
    if(sum == n)
    {
        for(int i = 0;i<depth;i++)
            printf("%d ",mem[i]);
        printf("\n");
        return ;
    }
    mem[depth] = 1;
    fun(1,sum+1,mem,depth+1,n);
    mem[depth] = 2;
    fun(2,sum+2,mem,depth+1,n);
}
int main()
{
    int i,j,n;
    while(EOF != scanf("%d",&n))
    {
        int mem[64] = {0};
        fun(0,0,mem,0,n);
    }
}

                                         
===========深入<----------------->浅出============
2011-08-09 18:12
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
第三问  就是把第二问的2改成n可以了
程序代码:
#include<stdio.h>
#define MAX 65
int step = 0;
void fun(int d,int sum,int mem[],int depth,int n)//走几步 只有1 2,当前走的总步数,存储步数,递归深度,走几层
{
    if(sum > n)//剪枝
        return ;
    if(sum == n)
    {
        for(int i = 0;i<depth;i++)
            printf("%d ",mem[i]);
        printf("\n");
        return ;
    }
    for(int i = 1;i<=step;i++)
    {
        mem[depth] = i;
        fun(i,sum+i,mem,depth+1,n);
    }
}
int main()
{
    int i,j,n;
    while(EOF != scanf("%d %d",&n,&step))
    {
        int mem[64] = {0};
        fun(0,0,mem,0,n);
    }
}

                                         
===========深入<----------------->浅出============
2011-08-09 18:15
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
下面的都差不多  只要改下面的这个for循环递归九可以了
第四问:
for(int i = m;i<=m+k;i++)
    {
        mem[depth] = i;
        fun(i,sum+i,mem,depth+1,n);
    }
第五问:
先用数组把那些可行的步数保存  int sets[1000] = {0}; int n;//有多少中迈步法
for(int i = 0;i<n;i++)
    {
        mem[depth] = sets[i];
        fun(sets[i],sum+sets[i],mem,depth+1,n);
    }

                                         
===========深入<----------------->浅出============
2011-08-09 18:19
q7408695
Rank: 2
等 级:论坛游民
帖 子:22
专家分:50
注 册:2011-8-2
收藏
得分:0 
回复 7楼 laoyang103
高手。这么速度就解决了。
2011-08-09 18:44
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
我是菜鸟

                                         
===========深入<----------------->浅出============
2011-08-09 18:54
wushaojun321
Rank: 2
等 级:论坛游民
帖 子:24
专家分:17
注 册:2011-8-6
收藏
得分:7 
这叫菜鸟啊??? 哭了     我要怎么才能到这种境界啊??
2011-08-09 19:02
快速回复:论坛高手瞧一瞧~有题目求交流。
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.014485 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved