aboutsummaryrefslogtreecommitdiff
path: root/contests/Round#788/A(2_pointers).cpp
diff options
context:
space:
mode:
authorOmar Magdy <omar.professional8777@gmail.com>2022-05-06 23:24:22 +0200
committerOmar Magdy <omar.professional8777@gmail.com>2022-05-06 23:24:22 +0200
commit9dce6eaf425178ab1c37dc15b3a74f09e23e9243 (patch)
treeb5897bda0f49f15b0d6d96d470e10603e2220189 /contests/Round#788/A(2_pointers).cpp
parented4b0690e4ee35278bb656c703bd0a1ab102222f (diff)
downloadcompetitive-programming-9dce6eaf425178ab1c37dc15b3a74f09e23e9243.tar.xz
competitive-programming-9dce6eaf425178ab1c37dc15b3a74f09e23e9243.zip
Added contests file
Diffstat (limited to 'contests/Round#788/A(2_pointers).cpp')
-rw-r--r--contests/Round#788/A(2_pointers).cpp29
1 files changed, 29 insertions, 0 deletions
diff --git a/contests/Round#788/A(2_pointers).cpp b/contests/Round#788/A(2_pointers).cpp
new file mode 100644
index 0000000..5d56719
--- /dev/null
+++ b/contests/Round#788/A(2_pointers).cpp
@@ -0,0 +1,29 @@
+#include<bits/stdc++.h>
+using namespace std;
+int main () {
+ int tt;
+ cin >> tt;
+ while (tt--) {
+ int n;
+ cin >> n;
+ vector<int> v(n);
+ for(auto &x : v) {
+ cin >> x;
+ }
+ int l = 0, r = v.size() - 1;
+ while(r > l) {
+ while(v[l] < 0) {
+ l++;
+ }
+ while(v[r] > 0) {
+ r--;
+ }
+ if(l > r) break;
+ v[l] = -v[l];
+ v[r] = -v[r];
+ }
+ cout << (is_sorted(v.begin(), v.end()) ? "YES" : "NO");
+ }
+}
+
+