PAT:1053. Path of Equal Weight (30) AC

#include<stdio.h>
#include<vector>
#include<queue>
#include<algorithm>
using namespace std;
const int MAX=1010;

int n,m;        //n个节点,m个非叶子节点
long long int S;    //待测权值

long long int weight[MAX];  //每个节点的权值

vector<int> child[MAX];    //存储节点

bool cmp(int a,int b)
{
  return weight[a]>weight[b];
}

long long int sum=0;
vector<int> path;  //存路径权值
void DFS(int root)
{
  if(child[root].size()==0)
  {
    if(sum==S)
    {
      printf("%d",path.front());    //权值S不为0,符合条件一定有路径。单独输出首个,控制后面空格数
      for(int i=1 ; i<path.size() ; ++i)
        printf(" %d",path[i]);    //输出剩余路径
      printf("\n");
    }
    return;
  }
  for(int i=0 ; i<child[root].size() ; ++i)
  {
    sum+=weight[child[root][i]];    //加上该孩子的权值
    //printf("root=%d, i=%d, sum=%lld, child[root][i]=%d\n", root, i, sum, child[root][i]);
    path.push_back(weight[child[root][i]]);    //该孩子加入到路径
    DFS(child[root][i]);
    sum-=path[path.size()-1];
    path.pop_back();
  }
}
int main()
{
  scanf("%d%d%lld",&n,&m,&S);
  for(int i=0 ; i<n ; ++i)
    scanf("%lld",&weight[i]);
  for(int i=0 ; i<m ; ++i)
  {
    int father,k,c;
    scanf("%d%d",&father,&k);
    for(int j=0 ; j<k ; ++j)
    {
      scanf("%d",&c);
      child[father].push_back(c);
    }
    sort(child[father].begin(),child[father].end(),cmp);    //【skill】对vector进行排序,保证遍历的时候从大到小
  }
  path.push_back(weight[0]);
  sum+=weight[0];
  DFS(0);
  return 0;
}
时间: 2024-08-26 18:43:02

PAT:1053. Path of Equal Weight (30) AC的相关文章

PAT Advanced 1053 Path of Equal Weight (30) [树的遍历]

题目 Given a non-empty tree with root R, and with weight Wi assigned to each tree node Ti. The weight of a path from R to L is defined to be the sum of the weights of all the nodes along the path from R to any leaf node L. Now given any weighted tree,

PAT 1053. Path of Equal Weight (30)

1053. Path of Equal Weight (30) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue Given a non-empty tree with root R, and with weight Wi assigned to each tree node Ti. The weight of a path from R to Lis defined to be the sum of the

1053. Path of Equal Weight (30)

dfs函数携带vector形参记录搜索路径 时间限制 10 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue Given a non-empty tree with root R, and with weight Wi assigned to each tree node Ti. The weight of a path from R to L is defined to be the sum of the weights of

PAT (Advanced Level) 1053. Path of Equal Weight (30)

简单DFS #include<cstdio> #include<cstring> #include<cmath> #include<vector> #include<map> #include<queue> #include<stack> #include<string> #include<algorithm> using namespace std; const int maxn=100+10;

PAT甲题题解-1053. Path of Equal Weight (30)-dfs

由于最后输出的路径排序是降序输出,相当于dfs的时候应该先遍历w最大的子节点. 链式前向星的遍历是从最后add的子节点开始,最后添加的应该是w最大的子节点, 因此建树的时候先对child按w从小到大排序,然后再add建边. 水题一个,不多说了. #include <iostream> #include <algorithm> #include <cstdio> #include <string.h> using namespace std; const in

1053 Path of Equal Weight (30分)(并查集)

Given a non-empty tree with root R, and with weight W?i?? assigned to each tree node T?i??. The weight of a path from R to L is defined to be the sum of the weights of all the nodes along the path from R to any leaf node L. Now given any weighted tre

1053 Path of Equal Weight (30分)

1. 题目 2. 思路 定义结构体, 并且使用下标作为序号 struct node{ string weight; vector<int> children; }nodes[101]; 读取数据,并且排序children,方便输出 使用先序遍历,处理数据 3. 注意点 权重的值很大,用字符串处理,要自己写加法和比较函数 4. 代码 #include<cstdio> #include<algorithm> #include<vector> #include&l

PAT Advanced Level 1053 Path of Equal Weight

1053 Path of Equal Weight (30)(30 分) Given a non-empty tree with root R, and with weight W~i~ assigned to each tree node T~i~. The weight of a path from R to L is defined to be the sum of the weights of all the nodes along the path from R to any leaf

pat1053. Path of Equal Weight (30)

1053. Path of Equal Weight (30) 时间限制 10 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue Given a non-empty tree with root R, and with weight Wi assigned to each tree node Ti. The weight of a path from R to L is defined to be the sum of the