| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1134 人关注过本帖
标题:请问下面代码中v[i]=0是什么时候执行的,深搜回朔是怎么实现的
取消只看楼主 加入收藏
huangmeixin
Rank: 2
等 级:论坛游民
帖 子:13
专家分:20
注 册:2018-11-14
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:0 
请问下面代码中v[i]=0是什么时候执行的,深搜回朔是怎么实现的
//代码的功能为输出全排列
#include<iostream>
using namespace std;
int n,a[100],v[100];
//a数组用于保存每一次的排列,v数组用于判断数字是不是已经被选过
void dfs(int dp)//dp从1到n,执行n次,每次选择一个数
{
    if(dp>n)//dp为n+1的时候,就说明已经选了n个,可以输出了;
    {
        for(int i=1;i<=n;i++)
        {
            cout<<a[i]<<" ";
        }
        cout<<endl;
        return;
    }
    for(int i=1;i<=n;i++)
    {
        if(!v[i])//判断是不是选择过
        {
            a[dp]=i;//保存当前选择
            v[i]=1;//标记这个数字,防止同一个排列选择相同的数字。
            dfs(dp+1);
            v[i]=0;//回溯回来的时候一定要清楚标记,不然下一个排列就能选择了,这也是最关键的地方,仔细思考一下。
        }
    }
}
int main()
{
    while(cin>>n)
    {
        dfs(1);
    }
}
搜索更多相关主题的帖子: 代码 执行 排列 int 选择 
2018-12-24 23:56
快速回复:请问下面代码中v[i]=0是什么时候执行的,深搜回朔是怎么实现的
数据加载中...
 
   



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

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