标签:Paths 剪枝 1155 ismin 30 int 回溯 root
1155 Heap Paths (30 分)
这道题目解析:
这道题目是从根到尾进行遍历,并且利用回溯剪枝进行回溯。
由于完全二叉树,具有节点i,它的父亲i/2,它的左孩子2i,它的右孩子2i+1.,判断是否是最大堆,还是最小堆,需要设置两个变量,ismin,和ismax,从而进行判断。
回溯剪枝方法我不是很擅长,我只知道,塞进去,遍历,出来这种处理方法,再加上输出条件,和边界条件,就可以实现了。
下面附上完整的代码
#include<iostream>
#include<vector>
using namespace std;
vector<int>m;
void DFS(vector<int>v,int n, int root){
if(root>n) return;
if(root>n/2){
for(unsigned int i=0;i<m.size();i++){
cout<<v[m[i]];
if(i!=m.size()-1) cout<<" ";
else cout<<endl;
}
}
m.push_back(root*2+1);
DFS(v,n,root*2+1);
m.pop_back();
m.push_back(root*2);
DFS(v,n,root*2);
m.pop_back();
}
int main(){
int n;
cin>>n;
vector<int>v(n+1);
for(int i=0;i<n;i++)
cin>>v[i+1];
m.push_back(1);
DFS(v,n,1);
int ismax=1,ismin=1;
for(int i=2;i<=n;i++){
if(v[i/2]>v[i]) ismin=0;
if(v[i/2]<v[i]) ismax=0;
}
if(ismax==1) cout<<"Max Heap"<<endl;
else if(ismin==1) cout<<"Min Heap"<<endl;
else cout<<"Not Heap"<<endl;
}
标签:Paths,剪枝,1155,ismin,30,int,回溯,root 来源: https://blog.csdn.net/qq_43733265/article/details/113784016
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。