diff options
author | crupest <crupest@outlook.com> | 2021-02-24 00:36:15 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2021-02-24 00:36:15 +0800 |
commit | 90375859767eb4cae3a7a93c64725b504d7f0fe0 (patch) | |
tree | f8fcda952bbd2bbd9a6d9a2a2dfad1cb99d5d624 /works/life/chuanzhi-cup | |
parent | 93b0dad49c78c22cda374239eda5a77baeb358b1 (diff) | |
download | crupest-90375859767eb4cae3a7a93c64725b504d7f0fe0.tar.gz crupest-90375859767eb4cae3a7a93c64725b504d7f0fe0.tar.bz2 crupest-90375859767eb4cae3a7a93c64725b504d7f0fe0.zip |
import(life): Add chuanzhi-cup codes.
Diffstat (limited to 'works/life/chuanzhi-cup')
-rw-r--r-- | works/life/chuanzhi-cup/.clangd | 2 | ||||
-rw-r--r-- | works/life/chuanzhi-cup/.gitignore | 1 | ||||
-rw-r--r-- | works/life/chuanzhi-cup/README.md | 1 | ||||
-rw-r--r-- | works/life/chuanzhi-cup/contest/1.cpp | 22 | ||||
-rw-r--r-- | works/life/chuanzhi-cup/contest/2.cpp | 28 | ||||
-rw-r--r-- | works/life/chuanzhi-cup/contest/3.cpp | 46 | ||||
-rw-r--r-- | works/life/chuanzhi-cup/contest/4.cpp | 48 | ||||
-rw-r--r-- | works/life/chuanzhi-cup/practice-contest/1.cpp | 27 | ||||
-rw-r--r-- | works/life/chuanzhi-cup/practice-contest/2.cpp | 30 | ||||
-rw-r--r-- | works/life/chuanzhi-cup/practice-contest/3.cpp | 38 | ||||
-rw-r--r-- | works/life/chuanzhi-cup/practice-contest/4.cpp | 47 |
11 files changed, 290 insertions, 0 deletions
diff --git a/works/life/chuanzhi-cup/.clangd b/works/life/chuanzhi-cup/.clangd new file mode 100644 index 0000000..d31be00 --- /dev/null +++ b/works/life/chuanzhi-cup/.clangd @@ -0,0 +1,2 @@ +CompileFlags:
+ Add: [-std=c++17]
\ No newline at end of file diff --git a/works/life/chuanzhi-cup/.gitignore b/works/life/chuanzhi-cup/.gitignore new file mode 100644 index 0000000..1feae78 --- /dev/null +++ b/works/life/chuanzhi-cup/.gitignore @@ -0,0 +1 @@ +*.exe
diff --git a/works/life/chuanzhi-cup/README.md b/works/life/chuanzhi-cup/README.md new file mode 100644 index 0000000..5fb89b7 --- /dev/null +++ b/works/life/chuanzhi-cup/README.md @@ -0,0 +1 @@ +此文件夹下是我参加传智杯写的垃圾代码。
diff --git a/works/life/chuanzhi-cup/contest/1.cpp b/works/life/chuanzhi-cup/contest/1.cpp new file mode 100644 index 0000000..4a20d97 --- /dev/null +++ b/works/life/chuanzhi-cup/contest/1.cpp @@ -0,0 +1,22 @@ +#include <cstdio>
+
+int main() {
+ int n, v, m, a;
+ std::scanf("%d%d%d%d", &n, &v, &m, &a);
+
+ int money = 0;
+
+ v -= a;
+
+ for (int i = 0; i < n; i++) {
+ if (i % m == 0) {
+ v += a;
+ }
+
+ money += v;
+ }
+
+ std::printf("%d", money);
+
+ return 0;
+}
\ No newline at end of file diff --git a/works/life/chuanzhi-cup/contest/2.cpp b/works/life/chuanzhi-cup/contest/2.cpp new file mode 100644 index 0000000..358e7fc --- /dev/null +++ b/works/life/chuanzhi-cup/contest/2.cpp @@ -0,0 +1,28 @@ +#include <cmath>
+#include <cstdio>
+
+int main() {
+ int x;
+ std::scanf("%d", &x);
+
+ double gpa;
+
+ if (x >= 90)
+ gpa = 4.0;
+ else if (x >= 60) {
+ gpa = (x - 50.0) / 10.0;
+ } else {
+ int s = std::floor(std::sqrt(x) * 10.0);
+ if (s >= 90)
+ gpa = 4.0;
+ else if (s >= 60) {
+ gpa = (s - 50.0) / 10.0;
+ } else {
+ gpa = 0;
+ }
+ }
+
+ std::printf("%.1f", gpa);
+
+ return 0;
+}
\ No newline at end of file diff --git a/works/life/chuanzhi-cup/contest/3.cpp b/works/life/chuanzhi-cup/contest/3.cpp new file mode 100644 index 0000000..8f0769d --- /dev/null +++ b/works/life/chuanzhi-cup/contest/3.cpp @@ -0,0 +1,46 @@ +#include <cstdio>
+#include <set>
+
+struct V {
+ V(int n, int t, int k) : n(n), t(t), k(k), c(t * k) {}
+
+ int n;
+ int t;
+ int k;
+ const int c;
+};
+
+struct C {
+ bool operator()(const V &left, const V &right) const {
+ if (left.c > right.c)
+ return true;
+ else if (left.c < right.c)
+ return false;
+ else if (left.t > right.t)
+ return true;
+ else if (left.t < right.t)
+ return false;
+ else if (left.n < right.n)
+ return true;
+ return false;
+ }
+};
+
+int main() {
+ std::set<V, C> data;
+
+ int n;
+ std::scanf("%d", &n);
+
+ for (int i = 1; i <= n; i++) {
+ int t, k;
+ std::scanf("%d%d", &t, &k);
+ data.insert(V{i, t, k});
+ }
+
+ for (const auto &v : data) {
+ std::printf("%d ", v.n);
+ }
+
+ return 0;
+}
\ No newline at end of file diff --git a/works/life/chuanzhi-cup/contest/4.cpp b/works/life/chuanzhi-cup/contest/4.cpp new file mode 100644 index 0000000..da01a23 --- /dev/null +++ b/works/life/chuanzhi-cup/contest/4.cpp @@ -0,0 +1,48 @@ +#include <algorithm>
+#include <cstdio>
+#include <iostream>
+#include <string>
+#include <vector>
+
+int main() {
+ std::vector<std::string> files;
+ int n;
+ std::cin >> n;
+ int current_count = 0;
+ while (current_count < n) {
+ std::string command;
+ std::cin >> command;
+ char a = command[0];
+ if (a == 't') {
+ std::string file;
+ std::cin >> file;
+ auto iter = std::find(files.cbegin(), files.cend(), file);
+ if (iter == files.cend()) {
+ files.push_back(std::move(file));
+ }
+ } else if (a == 'l') {
+ for (const auto &f : files) {
+ std::cout << f << '\n';
+ }
+ } else {
+ char b = command[1];
+ if (b == 'm') {
+ std::string file;
+ auto iter = std::find(files.cbegin(), files.cend(), file);
+ if (iter != files.cend())
+ files.erase(iter);
+ } else {
+ std::string old, new_f;
+ std::cin >> old >> new_f;
+ auto iter = std::find(files.begin(), files.end(), old);
+ auto iter2 = std::find(files.begin(), files.end(), new_f);
+ if (iter != files.end() && iter2 == files.end()) {
+ *iter = std::move(new_f);
+ }
+ }
+ }
+ current_count++;
+ }
+
+ return 0;
+}
diff --git a/works/life/chuanzhi-cup/practice-contest/1.cpp b/works/life/chuanzhi-cup/practice-contest/1.cpp new file mode 100644 index 0000000..1a0d88e --- /dev/null +++ b/works/life/chuanzhi-cup/practice-contest/1.cpp @@ -0,0 +1,27 @@ +#include <iostream>
+
+int main() {
+ int n;
+ std::cin >> n;
+
+ int count = 0;
+
+ for (int i = 1; i <= n; i++) {
+ int num = i;
+ int sum = 0;
+ while (num != 0) {
+ sum += num % 10;
+ num /= 10;
+
+ if (sum > 9)
+ break;
+ }
+
+ if (sum == 9)
+ count++;
+ }
+
+ std::cout << count;
+
+ return 0;
+}
diff --git a/works/life/chuanzhi-cup/practice-contest/2.cpp b/works/life/chuanzhi-cup/practice-contest/2.cpp new file mode 100644 index 0000000..5622eb4 --- /dev/null +++ b/works/life/chuanzhi-cup/practice-contest/2.cpp @@ -0,0 +1,30 @@ +#include <iostream>
+
+long long sqrt(long long num) {
+ long long left = 1, right = num;
+ while (left != right) {
+ long long mid = (left + right) / 2;
+ if (mid * mid < num) {
+ left = mid + 1;
+ } else {
+ right = mid;
+ }
+ }
+ return left;
+}
+
+int main() {
+ long long c;
+ std::cin >> c;
+
+ for (long long i = 1; i < c; i++) {
+ long long b2 = c * c - i * i;
+ long long b = sqrt(b2);
+ if (b * b == b2) {
+ std::cout << i << " " << b;
+ break;
+ }
+ }
+
+ return 0;
+}
diff --git a/works/life/chuanzhi-cup/practice-contest/3.cpp b/works/life/chuanzhi-cup/practice-contest/3.cpp new file mode 100644 index 0000000..1f79723 --- /dev/null +++ b/works/life/chuanzhi-cup/practice-contest/3.cpp @@ -0,0 +1,38 @@ +#include <cmath>
+#include <iomanip>
+#include <iostream>
+#include <regex>
+#include <string>
+
+int main() {
+ std::string input;
+ std::getline(std::cin, input);
+
+ std::regex reg(R"aaa((\d+)([GMK]?B)=\?([GMK]?B))aaa");
+ std::smatch match;
+ std::regex_match(input, match, reg);
+
+ std::string original_number_str = match[1].str();
+ std::string original_unit = match[2].str();
+ std::string target_unit = match[3].str();
+
+ double original_number = std::stod(original_number_str);
+
+ auto to_ratio = [](const std::string s) -> double {
+ if (s.size() == 1)
+ return 1;
+ if (s[0] == 'G')
+ return std::pow(2, 30);
+ if (s[0] == 'M')
+ return std::pow(2, 20);
+ return std::pow(2, 10);
+ };
+
+ double original_ratio = to_ratio(original_unit);
+ double target_ratio = to_ratio(target_unit);
+
+ std::cout << std::fixed << std::setprecision(6)
+ << (original_number * original_ratio / target_ratio);
+
+ return 0;
+}
diff --git a/works/life/chuanzhi-cup/practice-contest/4.cpp b/works/life/chuanzhi-cup/practice-contest/4.cpp new file mode 100644 index 0000000..bab6b2d --- /dev/null +++ b/works/life/chuanzhi-cup/practice-contest/4.cpp @@ -0,0 +1,47 @@ +#include <algorithm>
+#include <iomanip>
+#include <iostream>
+
+int score[1000001];
+double result[1000001];
+
+int main() {
+ int min;
+ int max;
+ int sum = 0;
+
+ int count;
+ std::cin >> count;
+
+ for (int i = 1; i <= count; i++) {
+ std::cin >> score[i];
+ }
+
+ int n1 = score[1], n2 = score[2];
+ sum += n1 + n2;
+ min = std::min(n1, n2);
+ max = std::max(n1, n2);
+
+ for (int i = 3; i <= count; i++) {
+ int current = score[i];
+
+ min = std::min(current, min);
+ max = std::max(current, max);
+
+ sum += current;
+
+ int s = sum;
+ s -= min;
+ s -= max;
+
+ result[i] = static_cast<double>(s) / (i - 2);
+ }
+
+ std::cout << std::fixed << std::setprecision(2);
+
+ for (int i = 3; i <= count; i++) {
+ std::cout << result[i] << "\n";
+ }
+
+ return 0;
+}
|