个人使用BFS出现这个问题。。。百思不得其解,请指教
结果测评:
代码如下所示:
#include<iostream>
#include<stdlib.h>
#include<stdio.h>
#include<vector>
#include<queue>
#include<algorithm>
#include<math.h>
using namespace std;
using std::vector;
using std::queue;
const int maxn=100010;
struct node{
double data;
vector<int>child;
int layer;
}Node[maxn];
int n;
double p,r;
bool cmp(node a,node b){
return a.layer>b.layer;
}
void BFS(int x){
int layer=-1;
queue<int>q;
q.push(x);
while(!q.empty()){
layer++;
int length=q.size();
for(int i=0;i<length;i++){
int index=q.front();
q.pop();
Node[index].layer=layer;
for(int j=0;j<Node[index].child.size();j++){
q.push(Node[index].child[j]);
}
}
}
}
int main(){
int root;
int mem;
scanf("%d%lf%lf",&n,&p,&r);
for(int i=0;i<n;i++){
scanf("%d",&mem);
if(mem!=-1){
//如果不是根节点
Node[mem].child.push_back(i);
}else{
root=i;
}
}
BFS(root);
sort(Node,Node+n,cmp);
int layer=Node[0].layer;
int sum=0;
for(int i=0;i<n;i++){
if(Node[i].layer==layer)
sum++;
}
printf("%.2f %d",p*pow(1+r/100,layer),sum);
system("pause");
return 0;
}
思路
题意就是求一棵树的高度,只需要一次bfs即可。
时间复杂度为O(n),这题n的范围是小于n<=10^5,可以通过这个题。
你的代码确实很乱,而且思路不够清晰,请对照我的代码,看我有哪些优化的地方。
有问题可以评论或私信。
AC代码