enh(CPlusPlus): fix indent stock span problem (#673)
parent
564b5db025
commit
65caa7adf9
|
@ -4,67 +4,63 @@
|
||||||
|
|
||||||
#include <bits/stdc++.h>
|
#include <bits/stdc++.h>
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
// A stack based efficient method to calculate
|
// A stack based efficient method to calculate
|
||||||
// stock span values
|
// stock span values
|
||||||
void calculateSpan(const vector<int> price, const int n,vector<int>& S)
|
void calculateSpan(const vector<int> price, const int priceSize,vector<int>& stockSpan)
|
||||||
{
|
{
|
||||||
// Create a stack and push index of first
|
stack<int> spanStack;
|
||||||
// element to it
|
spanStack.push(0);
|
||||||
stack<int> st;
|
|
||||||
st.push(0);
|
|
||||||
|
|
||||||
// Span value of first element is always 1
|
// Span value of first element is always 1
|
||||||
S.push_back(1);
|
stockSpan.push_back(1);
|
||||||
|
|
||||||
// Calculate span values for rest of the elements
|
// Calculate span values for rest of the elements
|
||||||
for (int i = 1; i < n; i++) {
|
for (int priceIt = 1; priceIt < priceSize; priceIt++) {
|
||||||
// Pop elements from stack while stack is not
|
while (!spanStack.empty() && (price[spanStack.top()] < price[priceIt]) )
|
||||||
// empty and top of stack is smaller than
|
spanStack.pop();
|
||||||
// price[i]
|
|
||||||
while (!st.empty() && price[st.top()] < price[i])
|
|
||||||
st.pop();
|
|
||||||
|
|
||||||
// If stack becomes empty, then price[i] is
|
// If stack becomes empty, then price[i] is
|
||||||
// greater than all elements on left of it,
|
// greater than all elements on left of it,
|
||||||
// i.e., price[0], price[1], ..price[i-1]. Else
|
// i.e., price[0], price[1], ..price[priceSize-1]. Else
|
||||||
// price[i] is greater than elements after
|
// price[priceSize] is greater than elements after
|
||||||
// top of stack
|
// top of stack
|
||||||
int x = (st.empty()) ? (i + 1) : (i - st.top());
|
stockSpan.push_back( (spanStack.empty()) ? (priceIt + 1) : (priceIt - spanStack.top()) );
|
||||||
S.push_back(x);
|
|
||||||
|
spanStack.push(priceIt);
|
||||||
// Push this element to stack
|
|
||||||
st.push(i);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// A utility function to print elements of array
|
//Print elements of array
|
||||||
void printArray(const vector<int>& arr,const int n)
|
void printArray(const vector<int>& arr,const int arrSize)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < n; i++)
|
for (int arrIt = 0; arrIt < arrSize; arrIt++)
|
||||||
cout << arr[i] << " ";
|
cout << arr[arrIt] << " ";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Return the price vector from user input
|
||||||
|
vector<int> getPrice()
|
||||||
|
{
|
||||||
|
vector<int> price;
|
||||||
|
int priceSize;
|
||||||
|
cin>>priceSize;
|
||||||
|
for(int sizeIt = 0 ; sizeIt < priceSize ; sizeIt++)
|
||||||
|
{
|
||||||
|
int priceEntry;
|
||||||
|
cin>>priceEntry;
|
||||||
|
price.push_back(priceEntry);
|
||||||
|
}
|
||||||
|
return price;
|
||||||
|
}
|
||||||
|
|
||||||
// Driver program to test above function
|
// Driver program to test above function
|
||||||
int main()
|
int main()
|
||||||
{
|
{
|
||||||
vector<int> price;
|
vector<int> price = getPrice();
|
||||||
int n;
|
vector<int> stockSpan;
|
||||||
//Enter the size of price
|
calculateSpan(price, price.size(), stockSpan);
|
||||||
cin>>n;
|
|
||||||
vector<int> S;
|
printArray(stockSpan, price.size());
|
||||||
for(int i=0;i<n;i++)
|
|
||||||
{
|
|
||||||
int x;
|
|
||||||
cin>>x;
|
|
||||||
price.push_back(x);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fill the span values in array S[]
|
|
||||||
calculateSpan(price, n, S);
|
|
||||||
|
|
||||||
// print the calculated span values
|
|
||||||
printArray(S, n);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue