#include <algorithm>
#include <cassert>
#include <numeric>
#include <vector>

class Solution {
  public:
    std::vector<int> getSumAbsoluteDifferences(const std::vector<int> &nums) {
        auto total = std::accumulate(nums.begin(), nums.end(), 0);

        auto left = 0;
        std::vector<int> result;
        for (auto i = 0u; i < nums.size(); ++i) {
            auto left_diff = i * nums[i] - left;

            auto right = total - nums[i] - left;
            auto right_diff = right - (nums.size() - i - 1) * nums[i];

            result.push_back(left_diff + right_diff);

            left += nums[i];
        }

        return result;
    }
};

int main() {
    Solution s;

    assert((s.getSumAbsoluteDifferences(std::vector{2, 3, 5}) ==
            std::vector{4, 3, 5}));
    assert((s.getSumAbsoluteDifferences(std::vector{1, 4, 6, 8, 10}) ==
            std::vector{24, 15, 13, 15, 21}));
    return 0;
}