Back to all solutions
#3068 - Find the Maximum Sum of Node Values
Problem Description
There exists an undirected tree with n nodes numbered 0 to n - 1. You are given a 0-indexed 2D integer array edges of length n - 1, where edges[i] = [ui, vi] indicates that there is an edge between nodes ui and vi in the tree. You are also given a positive integer k, and a 0-indexed array of non-negative integers nums of length n, where nums[i] represents the value of the node numbered i.
Alice wants the sum of values of tree nodes to be maximum, for which Alice can perform the following operation any number of times (including zero) on the tree:
- Choose any edge [u, v] connecting the nodes u and v, and update their values as follows:- nums[u] = nums[u] XOR k
- nums[v] = nums[v] XOR k
 
Return the maximum possible sum of the values Alice can achieve by performing the operation any number of times.
Solution
/**
 * @param {number[]} nums
 * @param {number} k
 * @param {number[][]} edges
 * @return {number}
 */
var maximumValueSum = function(nums, k, edges) {
  let totalSum = 0;
  let minChange = Infinity;
  let changeCount = 0;
  for (const num of nums) {
    const xored = num ^ k;
    const change = xored - num;
    if (change > 0) {
      totalSum += xored;
      changeCount++;
    } else {
      totalSum += num;
    }
    minChange = Math.min(minChange, Math.abs(change));
  }
  if (changeCount % 2 === 0) {
    return totalSum;
  }
  return totalSum - minChange;
};