-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathSorting the Skills.cpp
114 lines (84 loc) · 2.3 KB
/
Sorting the Skills.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
/*
PROBLEM:
There is a company named James Peterson & Co. The company has ‘n’ employees. The employees have skills from 0 to n-1. All the employees have distinct skills. The manager of James Peterson & Co. wants to sort the employees on the basis of their skills in ascending order. He is only allowed to swap two employees which are adjacent to each other. He is given the skills of employees in an array of size ‘n’. He can swap the skills as long as the absolute difference between their skills is 1. You need to help the manager out and tell whether it is possible to sort the skills of employees or not.
Input Format:
First Line will have an integer ‘t’ denoting the no. of test cases.
First line of each test case contains an integer ‘n’ denoting the no. of employees in the company.
Second line of each test case contains ‘n’ distinct integers in the range [0, n-1].
Output Format:
For each test case, print “Yes” if it is possible to sort the skills otherwise “No”.
Constraints:
1 <= t <= 10
1 <= n <= 10^5
Sample Input:
2
4
1 0 3 2
3
2 1 0
Sample Output:
Yes
No
Explanation:
In first T.C., [1, 0, 3, 2] -> [0, 1, 3, 2] -> [0, 1, 2, 3]
In second T.C., [2, 1, 0] -> [1, 2, 0] OR [2, 1, 0] -> [2, 0, 1] So, it is impossible to sort.
CODE:
*/
#include <bits/stdc++.h>
using namespace std;
bool skillSort(vector<int> &skills, int start, int end){
// cout << start<<" " <<end<< '\n';
if (start>= end)
{
return 1;
}
int n = skills.size();
int mid = (start+end)/2;
int left = skillSort(skills, start, mid);
int right = skillSort(skills, mid+1, end);
if (left!=1 || right != 1)
{
return 0;
}
if (skills[mid+1]>skills[mid])
{
return 1;
}
// cout << "mid "<<skills[mid] << '\n';
// cout << "mid+1 "<<skills[mid+1] << '\n';
if (skills[mid]-skills[mid+1]>1)
{
return 0;
}
if (skills[mid+1]<skills[mid])
{
swap(skills[mid], skills[mid+1]);
}
return 1;
}
int main( int argc , char ** argv )
{
ios_base::sync_with_stdio(false) ;
cin.tie(NULL) ;
int t;
cin>>t;
while(t--){
int n;
cin>>n;
//cout << "n "<<n << '\n';
std::vector<int> skills;
for (int i = 0; i < n; ++i)
{
int temp;
cin>>temp;
skills.push_back(temp);
}
if (skillSort(skills, 0, n-1)==1)
{
cout << "Yes" << '\n';
}else{
cout << "No" << '\n';
}
}
return 0 ;
}