c_cpp 递归四面体

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c_cpp 递归四面体相关的知识,希望对你有一定的参考价值。

#include <iostream>
#include<bits/stdc++.h>
using namespace std;
vector<int> vertices{1,2,3,4};
int getSteps(int N, int src, int dest)
{
    if(N==0)
        return 0;
    if(N==1)
        return 1;
    auto remaining_vertices = vertices;
    remaining_vertices.erase(remove_if(remaining_vertices.begin(), remaining_vertices.end(),[src](auto i){return i==src;}), remaining_vertices.end());
    copy(remaining_vertices.begin(), remaining_vertices.end(),ostream_iterator<int>(cout," "));
    
    return getSteps(N-1, remaining_vertices[0],dest) + getSteps(N-1, remaining_vertices[1],dest) +getSteps(N-1, remaining_vertices[2],dest);
}
int main() {
	int N=4;
	cout<<getSteps(N, 4,4);
	return 0;
}

以上是关于c_cpp 递归四面体的主要内容,如果未能解决你的问题,请参考以下文章

c_cpp 递归冒泡排序

c_cpp 冒泡排序 - 递归

c_cpp 递归合并

c_cpp 递归星2机问题

c_cpp 递归C插入排序

c_cpp 反向链表,迭代,递归