Skip to content

Commit

Permalink
Adding questions from section1 geekForgeeks
Browse files Browse the repository at this point in the history
  • Loading branch information
Nanashii76 committed Sep 23, 2024
1 parent 15a78e7 commit 3d7258b
Show file tree
Hide file tree
Showing 5 changed files with 144 additions and 0 deletions.
56 changes: 56 additions & 0 deletions geekForgeeks/section1/frequenceOfLimitedVector.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
#include <bits/stdc++.h>
using namespace std;

int lower_bound(vector<int> &arr, int x) {

int l = 0, r = arr.size() - 1, target = -1;
while(l <= r) {
int mid = l+r/2;
if(arr[mid] == x) {
target = mid;
r = mid-1;
arr[mid] = 0;
} else if (arr[mid] > x) {
r = mid-1;
} else {
l = mid+1;
}
}

return target;
}

int upper_bound(vector<int> &arr, int x) {

int l = 0, r = arr.size() - 1, target = -1;
while(l <= r) {
int mid = l+r/2;
if(arr[mid] == x) {
target = mid;
l = mid+1;
arr[mid] = 0;
} else if (arr[mid] > x) {
r = mid - 1;
} else {
l = mid+1;
}
}

return target;
}

void frequencyCount(vector<int>& arr, int N, int P) {

int size = arr.size() - 1;
sort(arr.begin(),arr.end());
for(int i = 0; i < size; ++i) {
if(arr[i] == 0)
continue;

int val = arr[i];
int f = lower_bound(arr, val);
int l = upper_bound(arr, val);
l = l-f+1;
arr[val-1] = l;
}
}
24 changes: 24 additions & 0 deletions geekForgeeks/section1/minAndMaxArray.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
#include <bits/stdc++.h>
using namespace std;

typedef long long ll;

pair<ll,ll> getMinMax(vector<ll> arr) {

int size = arr.size();
pair<ll,ll> minMax;
if(size == 1) {
minMax.first = minMax.second = arr[0];
return minMax;
}
minMax.first = LLONG_MAX;
minMax.second = LLONG_MIN;

for(int i = 0; i < size; ++i) {
minMax.first = min(minMax.first,arr[i]);
minMax.second = max(minMax.second,arr[i]);
}

return minMax;

}
13 changes: 13 additions & 0 deletions geekForgeeks/section1/palindromeString.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
#include <bits/stdc++.h>
using namespace std;

int isPalindrome(string S) {

int size = S.length();
for(int i = 0, j = size-1; i < (size/2); ++i, --j) {
if(S[i] != S[j])
return 0;
}

return 1;
}
16 changes: 16 additions & 0 deletions geekForgeeks/section1/reverseArray.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
#include <bits/stdc++.h>
using namespace std;

void reverseArray(vector<int> &arr) {
int size = arr.size()-1;
for(int i = 0; i < size; ++i) {
int temp = arr[i];
arr[i] = arr[size];
arr[size] = temp;
size--;
}
}

int main() {

}
35 changes: 35 additions & 0 deletions geekForgeeks/section1/reverseSquaredSum.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
#include <bits/stdc++.h>
using namespace std;

int squaredReverseSum(vector<int> vec) {

int size = vec.size() - 1, sum;
sum = vec[size]*vec[size];
bool sub = true;
for(int i = size-1; i >= 0; --i) {
if(sub) {
sum -= (vec[i] * vec[i]);
sub = false;
} else {
sum += (vec[i] * vec[i]);
sub = true;
}
}

return sum;
}

int main(){

int t, n;
cin >> t;
while(t--) {
cin >> n;
vector<int> vec(n);
for(int i = 0; i < n; ++i)
cin >> vec[i];
int ans = squaredReverseSum(vec);
cout << ans << endl;
}

}

0 comments on commit 3d7258b

Please sign in to comment.