| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 324 人关注过本帖
标题:求解释一段整数划分的程序(源代码如下)
只看楼主 加入收藏
nxychby
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2014-5-14
结帖率:0
收藏
已结贴  问题点数:20 回复次数:1 
求解释一段整数划分的程序(源代码如下)
#include<stdio.h>

int stack[100];
int top;
int total,n;

void dfs(int index)
{
    int i;
    if(total==n)     //当整体相等, 输出
    {
        printf("%d=",n);
        for(i=top-1;i>0;i--)
            printf("%d+",stack[i]);
        printf("%d\n",stack[0]);
    }
    if(total>n )     //大于错误,,不理会
        return ;
    for(i=n-1;i>=index;i--)    //遍历所有的数字
    {
        total+=i;  //获取这个情况
        stack[top++]=i; //存储,
        dfs(i); //递归
        total-=i; //递归结束后恢复。下同
        stack[--top];
    }
}

void main()
{
    while(scanf("%d",&n)!='\n')
    {
        top=0;
        total=0;
        dfs(1);
    }
}
搜索更多相关主题的帖子: include 源代码 return 
2014-05-14 22:36
CatherineZYR
Rank: 2
等 级:论坛游民
帖 子:5
专家分:25
注 册:2014-3-14
收藏
得分:20 
 深度优先算法~~~~~http://baike.
可以看一下,这个应该是数据结构中的内容,你可以去找找数据结构的书看看哈
2014-05-14 23:18
快速回复:求解释一段整数划分的程序(源代码如下)
数据加载中...
 
   



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

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