首页 > 其他 > 详细

回溯法

时间:2019-12-09 22:57:36      阅读:97      评论:0      收藏:0      [点我收藏+]

N皇后问题

 

递归:

技术分享图片
#include<iostream>
#include<vector>
#include<stack>
#include<cmath>
#include<cstring>
using namespace std;
typedef pair<int, int> P;
int n,sum;
vector<P> v;
bool judge(int x, int y){
    for (int i = 0; i < v.size(); i++){
        float bioas = (v[i].second*1.0 - y*1.0) / (v[i].first*1.0 - x * 1.0);
        if (x == v[i].first || y == v[i].second || abs(bioas) == 1.0)
            return false;
    }
    return true;
}
void trace(int index){
    if (index >= n){
        sum++;
        for (int i = 0; i < v.size(); i++)
            printf("(%d, %d) ", v[i].first, v[i].second);
        cout << endl;
        return;
    }
    for (int i = 0; i < n; i++){
        if (judge(index, i)){
            v.push_back(P(index, i));
            trace(index+1);
            v.erase(v.begin()+index, v.end());    
        }
    }
}


int main(){
    while(cin >> n){
        v.clear();
        sum = 0;
        trace(0);
        cout << sum << endl;
    }    
    return 0;
} 
View Code

迭代:

技术分享图片
#include<iostream>
#include<vector>
#include<stack>
#include<cmath>
#include<cstring>
using namespace std;
typedef pair<int, int> P;
int n,sum;
vector<P> v;
bool judge(int x, int y){
    for (int i = 0; i < v.size(); i++){
        float bioas = (v[i].second*1.0 - y*1.0) / (v[i].first*1.0 - x * 1.0);
        if (x == v[i].first || y == v[i].second || abs(bioas) == 1.0)
            return false;
    }
    return true;
}
void trace(int index){
    if (index >= n){
        sum++;
        for (int i = 0; i < v.size(); i++)
            printf("(%d, %d) ", v[i].first, v[i].second);
        cout << endl;
        return;
    }
    for (int i = 0; i < n; i++){
        if (judge(index, i)){
            v.push_back(P(index, i));
            trace(index+1);
            v.erase(v.begin()+index, v.end());    
        }
    }
}


int main(){
    while(cin >> n){
        v.clear();
        sum = 0;
        trace(0);
        cout << sum << endl;
    }    
    return 0;
} 
View Code

0-1背包问题

技术分享图片
#include<iostream>
#include<vector>
#include<sstream>
#include<algorithm>
using namespace std;
typedef pair<int, int> P;
int n, maxV, W;
string maxS;
vector<P> v;
bool cmp(P a, P b){
    return a.first > b.first;
}
void solve(int index, int sumV, int sumW, int fV, string s){
    if (maxV < sumV){
        maxV = sumV;
        maxS = s;
    }
    
    if (index >= n || maxV >= fV + sumV) return;
    string left = s;
    solve(index+1, sumV, sumW, fV - v[index].first, left);
    if(sumW + v[index].second <= W && sumV + fV > maxV){
        stringstream ss;
        ss << index+1;
        string right = s + + ss.str();
        solve(index+1, sumV + v[index].first, sumW + v[index].second, fV - v[index].first, right); 
    }
}
int main(){
    while(cin >> n >> W) {
        v.clear();
        maxS.clear();
        maxV = 0;
        int fV = 0;
        for (int i = 0; i < n; i++) {
            int x, w;
            cin >> x >> w;
            fV += x;
            v.push_back(P(x,w));
        }
        //sort(v.begin(), v.end(),cmp);
        string s="最佳解为:";
        solve(0, 0, 0, fV ,s);
        cout << maxV << endl;
        cout << maxS << endl;
    }
    return 0;
} 

/*
4 10
42 7
25 5
12 3
40 4


65
*/
View Code

 

回溯法

原文:https://www.cnblogs.com/astonc/p/12013692.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!