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 反向链表,迭代,递归