aboutsummaryrefslogtreecommitdiff
path: root/works/life/algorithm-experiment/3.1.cpp
diff options
context:
space:
mode:
authorYuqian Yang <crupest@crupest.life>2025-02-12 15:55:21 +0800
committerYuqian Yang <crupest@crupest.life>2025-02-12 15:55:21 +0800
commit10eb95869601e145b1d8bc909424777c25752d51 (patch)
tree49449a4076ded9bd937a51679318edbe2a532cae /works/life/algorithm-experiment/3.1.cpp
parent29ba3e88b1a7425fe00af0005b8a8228103aa21c (diff)
parentf8c10dd1fc55e60f35286475356e48c4f642eb63 (diff)
downloadcrupest-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.cpp38
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;
+}