diff options
| author | Omar Magdy <omar.professional8777@gmail.com> | 2022-05-30 00:18:17 +0200 |
|---|---|---|
| committer | Omar Magdy <omar.professional8777@gmail.com> | 2022-05-30 00:18:17 +0200 |
| commit | 3a89fc707253f75f46fd5a4822817f1fd5156c40 (patch) | |
| tree | 474b08b187895af91c10838aae21142b2ba2514d /cutTheSticks/cutTheSticks.cpp | |
| parent | f5ff62a26052f084b6b807cba220c86785fd45e3 (diff) | |
| download | competitive-programming-3a89fc707253f75f46fd5a4822817f1fd5156c40.tar.xz competitive-programming-3a89fc707253f75f46fd5a4822817f1fd5156c40.zip | |
Made that every problem is its own folder to make building the code a smooth operation with a shortcut
Diffstat (limited to 'cutTheSticks/cutTheSticks.cpp')
| -rw-r--r-- | cutTheSticks/cutTheSticks.cpp | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/cutTheSticks/cutTheSticks.cpp b/cutTheSticks/cutTheSticks.cpp new file mode 100644 index 0000000..5c2c700 --- /dev/null +++ b/cutTheSticks/cutTheSticks.cpp @@ -0,0 +1,63 @@ +#include<bits/stdc++.h> + +using namespace std; + +bool vectorZero(vector<int>& v); +int secondSmallest(vector<int>& v); + +int main(){ + int vsize; + int count=0; + vector<int> vec; + cin >> vsize; + vector<int> result; + for(int i = 0; i < vsize; i++){ + int element; + cin >> element; + vec.push_back(element); + } + sort(vec.begin(), vec.end()); + int mn = *min_element(vec.begin(), vec.end()); + for(int i = 0; i < vsize; i++){ + if(vec[i] != 0){ + vec[i]-= mn; + } + } + cout << vsize; + while(!vectorZero(vec)){ + int ss = vec[secondSmallest(vec)]; + count = 0; + for(int x : vec){ + cout << x << " "; + } + cout << endl; + for(int i = 0; i < vsize; i++){ + if(vec[i] != 0){ + vec[i] -= ss; + count++; + } + } + cout << count << endl; + } + return 0; +} + + +bool vectorZero(vector<int>& v){ + int count = 0; + for(int i = 0; i < v.size(); i++){ + if(v[i] == 0){ + count++; + } + } + return count == v.size(); +} + +int secondSmallest(vector<int>& v){ + for(int i = 0; i < v.size(); i++){ + if(v[i] != *min_element(v.begin(), v.end())){ + return i; + } + } + return -1; +} |
