diff options
author | Yuqian Yang <crupest@crupest.life> | 2025-02-12 15:55:21 +0800 |
---|---|---|
committer | Yuqian Yang <crupest@crupest.life> | 2025-02-12 15:55:21 +0800 |
commit | 10eb95869601e145b1d8bc909424777c25752d51 (patch) | |
tree | 49449a4076ded9bd937a51679318edbe2a532cae /works/life/algorithm-experiment/3.1.cpp | |
parent | 29ba3e88b1a7425fe00af0005b8a8228103aa21c (diff) | |
parent | f8c10dd1fc55e60f35286475356e48c4f642eb63 (diff) | |
download | crupest-10eb95869601e145b1d8bc909424777c25752d51.tar.gz crupest-10eb95869601e145b1d8bc909424777c25752d51.tar.bz2 crupest-10eb95869601e145b1d8bc909424777c25752d51.zip |
import(life): IMPORT crupest/life COMPLETE.
Diffstat (limited to 'works/life/algorithm-experiment/3.1.cpp')
-rw-r--r-- | works/life/algorithm-experiment/3.1.cpp | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/works/life/algorithm-experiment/3.1.cpp b/works/life/algorithm-experiment/3.1.cpp new file mode 100644 index 0000000..1796dc3 --- /dev/null +++ b/works/life/algorithm-experiment/3.1.cpp @@ -0,0 +1,38 @@ +#include <dlib/optimization/max_cost_assignment.h> +#include <iostream> +#include <vector> + +#include <dlib/optimization.h> + +int main() { + int n; + std::cin >> n; + + dlib::matrix<int> matrix(n, n); + + for (int i = 0; i < n; i++) { + for (int j = 0; j < n; j++) { + int l; + std::cin >> l; + matrix(i, j) = -l; + } + } + + auto result = dlib::max_cost_assignment(matrix); + + for (auto i : result) { + std::cout << i << ' '; + } + + std::cout << '\n'; + + int sum = 0; + + for (int i = 0; i < n; i++) { + sum += matrix(i, result[i]); + } + + std::cout << sum; + + return 0; +} |