diff options
| author | Omar Magdy <omar.professional8777@gmail.com> | 2022-05-06 23:24:22 +0200 |
|---|---|---|
| committer | Omar Magdy <omar.professional8777@gmail.com> | 2022-05-06 23:24:22 +0200 |
| commit | 9dce6eaf425178ab1c37dc15b3a74f09e23e9243 (patch) | |
| tree | b5897bda0f49f15b0d6d96d470e10603e2220189 /contests/Round#788/A.cpp | |
| parent | ed4b0690e4ee35278bb656c703bd0a1ab102222f (diff) | |
| download | competitive-programming-9dce6eaf425178ab1c37dc15b3a74f09e23e9243.tar.xz competitive-programming-9dce6eaf425178ab1c37dc15b3a74f09e23e9243.zip | |
Added contests file
Diffstat (limited to 'contests/Round#788/A.cpp')
| -rw-r--r-- | contests/Round#788/A.cpp | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/contests/Round#788/A.cpp b/contests/Round#788/A.cpp new file mode 100644 index 0000000..ada8036 --- /dev/null +++ b/contests/Round#788/A.cpp @@ -0,0 +1,50 @@ +#include<bits/stdc++.h> + +using namespace std; + +string solve(vector<int> v) { + int p = 0; + int n = 0; + for(int i = 0; i < v.size(); i++) { + if(v[i] > 0) { + p++; + } + else{ + n++; + } + } + int loop = min(p, n); + int loop1 = loop; + for(int i = 0; i < v.size(); i++) { + if(v[i] > 0 && loop != 0) { + v[i] = -v[i]; + loop--; + } + } + loop = min(p, n); + for(int i = v.size() - 1; i > 0; i--) { + if(v[i] < 0 && loop1 != 0) { + v[i] = -v[i]; + loop1--; + } + } + if(is_sorted(v.begin(), v.end())) { + return "YES"; + } + return "NO"; +} + + +int main () { + int tt; + cin >> tt; + while (tt--) { + int n; + cin >> n; + vector<int> v(n); + for(auto &x : v) { + cin >> x; + } + cout << solve(v) << endl; + } +} |
