【1053】Path of Equal Weight (30 分)

举报
野猪佩奇996 发表于 2022/01/23 01:18:41 2022/01/23
【摘要】 #include<iostream>#include<stdio.h>#include<stdlib.h>#include<math.h>#include<string.h>#include<algorithm> #include<map>#inclu...

  
  1. #include<iostream>
  2. #include<stdio.h>
  3. #include<stdlib.h>
  4. #include<math.h>
  5. #include<string.h>
  6. #include<algorithm>
  7. #include<map>
  8. #include<vector>
  9. #include<queue>
  10. using namespace std;
  11. const int MAXN=110;
  12. struct node{
  13. int weight; //数据域
  14. vector<int> child; //指针域
  15. }Node[MAXN]; //结点数组
  16. bool cmp(int a,int b){
  17. return Node[a].weight>Node[b].weight; //按结点数据域从大到小排序
  18. }
  19. int n,m,S; //结点数 边数 给定的和
  20. int path[MAXN];//记录路径
  21. //当前访问结点为index,numNode为当前路径path上的结点个数
  22. //sum为当前的结点点权和
  23. void DFS(int index,int numNode ,int sum){
  24. if(sum>S) return ;//当前和sum超过S,直接返回
  25. if(sum==S) { //如果当前和sum等于S
  26. if(Node[index].child.size() !=0) return;//还没有到叶子结点,直接返回
  27. //到达叶子结点,此时path[]存放了一条完整的路径,输出它
  28. for(int i=0;i<numNode;i++){
  29. printf("%d",Node[path[i]].weight);
  30. if(i<numNode-1) printf(" ");
  31. else printf("\n");
  32. }
  33. return ;// 返回
  34. }
  35. for(int i=0;i<Node[index].child.size() ;i++){ //枚举所有子结点
  36. int child=Node[index].child[i]; //结点index的第i的子结点编号
  37. path[numNode]=child;//将结点child加到路径path末尾
  38. DFS(child,numNode+1,sum+Node[child].weight); //递归进入下一层
  39. }
  40. }
  41. int main(){
  42. scanf("%d%d%d",&n,&m,&S);
  43. for(int i=0;i<n;i++){
  44. scanf("%d",&Node[i].weight);
  45. }
  46. int id,k,child;
  47. for(int i=0;i<m;i++){
  48. scanf("%d%d",&id,&k); //结点编号及孩子
  49. for(int j=0;j<k;j++){
  50. scanf("%d",&child);
  51. Node[id].child.push_back(child); //child为结点id的孩子
  52. }
  53. sort(Node[id].child.begin() , Node[id].child.end(),cmp); //排序
  54. }
  55. path[0]=0; //路径的第一个结点设置为0号结点
  56. DFS(0,1,Node[0].weight); //DFS求解
  57. system("pause");
  58. return 0;
  59. }

 

文章来源: andyguo.blog.csdn.net,作者:山顶夕景,版权归原作者所有,如需转载,请联系作者。

原文链接:andyguo.blog.csdn.net/article/details/99834849

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。