Advertisement
Rofyda_Elghadban1

Untitled

Mar 15th, 2024
24
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 3.04 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2. #define ll long long
  3. #define ull unsigned long long
  4. #define pi 3.141592654
  5. #define NUM 1e18
  6. #define Mod 1'000'000'007
  7. #define fixed(n) fixed<<setprecision(n)
  8. #define cin(v) for(auto &i:v) cin >> i ;
  9. #define cout(v) for(auto &i:v) cout << i <<" ";
  10. #define vowel(x) (x=='e'||x=='a'||x=='i'||x=='o'||x=='u')
  11. #define small(x) (x>=97&&x<=122)
  12. #define capital(x) (x>=65&&x<=90)
  13. #define Tolower(s) transform(s.begin(),s.end(),s.begin(),::tolower);
  14. #define Toupper(s) transform(s.begin(),s.end(),s.begin(),::toupper);
  15. #define sz(x) (int)(x.size())
  16. #define all(v) ((v).begin()), ((v).end())
  17. #define allr(v) ((v).rbegin()), ((v).rend())
  18. #define updmax(a,b) a=max(a,b)
  19. #define updmin(a,b) a=min(a,b)
  20. #define ceil(a,b) ((a/b)+(a%b?1:0))
  21. /* asc -> 1 2 3 ,des -> 3 2 1 */
  22.  
  23. /***********************************************************************************/
  24. using namespace std;
  25. void Rofyda_Elghadban(){
  26. #ifndef ONLINE_JUDGE
  27. freopen("input.txt", "r", stdin), freopen("output.txt", "w", stdout);
  28. #endif
  29. ios_base::sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr);
  30. }
  31.  
  32. void solve(){
  33. int n,n1=0,n2=0,counter=1,idx=0,flag=0;
  34. cin>>n;
  35. vector<int>v(n),v1,ans,temp;
  36. cin(v);
  37. v1=v;
  38. for(int i=0;i<v.size();i++){
  39. if(i+1<v.size()&&v[i]==v[i+1]){
  40. counter++;
  41. if(v[i]>9){
  42. n2=v1[i]%10;
  43. v1[i]/=10;
  44. n1=v1[i]%10;
  45. v1[i]/=10;
  46. temp.push_back(n1);
  47. temp.push_back(n2);
  48. }else{
  49. temp.push_back(v1[i]);
  50. }
  51. }
  52.  
  53. else
  54. if(counter>1){
  55. i--;
  56. }
  57. if(i+1<v.size()&&v[i]>v[i+1]){
  58. // if(counter>1){
  59. // while(counter>0){
  60. // // ans.pop_back();
  61. // counter--;
  62. // }
  63. // }
  64. counter=1;
  65. while(temp.size()>0){
  66. idx=temp.size()-1;
  67. ans.push_back(temp[idx]);
  68. idx--;
  69. temp.pop_back();
  70. // flag++;
  71. }
  72. // if(flag==0){
  73. if(v[i]>9){
  74. n2=v[i]%10;
  75. v[i]/=10;
  76. n1=v[i]%10;
  77. v[i]/=10;
  78. ans.push_back(n1);
  79. ans.push_back(n2);
  80. }else{
  81. ans.push_back(v[i]);
  82. }
  83. // }
  84. // flag=0;
  85. }
  86.  
  87. else{
  88. // if(counter>1){
  89. // i--;
  90. // }
  91. if(counter>1){
  92. while(counter>1){
  93. ans.push_back(v[i]);
  94. counter--;
  95. }
  96. }
  97. counter=1;
  98. // while(temp.size()>0){
  99. // idx=temp.size()-1;
  100. // ans.push_back(temp[idx]);
  101. // idx--;
  102. // temp.pop_back();
  103. // }
  104. // counter=1;
  105. ans.push_back(v[i]);
  106. }
  107. }
  108. // if(ans[ans.size()-1]==v[n-1]){
  109. // ans.push_back(ans[ans.size()-1]);
  110. // }
  111. cout(ans);
  112. cout<<"\n";
  113. for(int i=0;i<ans.size();i++){
  114. if(i+1<ans.size()&&ans[i]>ans[i+1]){
  115. cout<<"NO"<<"\n";
  116. return;
  117. }
  118. }
  119. cout<<"YES"<<"\n";
  120. }
  121.  
  122. int main(){
  123. Rofyda_Elghadban();
  124. int t=1;
  125. cin>>t;
  126. while(t--){
  127. solve();
  128. }
  129. return 0;
  130. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement