You're given an array containing both positive and negative
integers and required to find the sub-array with the largest
sum (O(N) a la KBL). Write a routine in C for the above.
Answer Posted / monti
#include<iostream>
using namespace std;
int maxsum(int arr[], int size, int& strt_index, int&
end_index){
int max=0;
for(int i =0;i<size;i++){
max += arr[i];
strt_index = 0;
end_index = size-1;
}
int strt = 0;
int sum;
for(int i=0;i<size;i++){
sum =0;
for(int j = i; j<size; j++){
sum += arr[j];
if(sum >=max){
max = sum;
strt_index = strt;
end_index = j;
}
}
strt++;
}
return max;
}
int main(){
int strt, end;
int arr[10] = {0, 4, -5, 13, 8, -11, -2, 7, 9, -11};
int maxsub = maxsum(arr, 10, strt, end);
cout<<"\nMAX Sub Sum is : "<<maxsub;
cout<<"\nstarting index : "<<strt;
cout<<"\nEnding index : "<<end<<endl<<endl;
system("Pause");
return 0;
}
Is This Answer Correct ? | 0 Yes | 5 No |
Post New Answer View All Answers
Who invented turbo c++?
Why cout is used in c++?
What is the difference between map and hashmap in c++?
What is auto used for in c++?
How do I use turbo c++?
When is the copy constructor called?
Explain friend class?
Is c++ built on c?
Why c++ is better than c language?
What is the difference between method overloading and method overriding in c++?
What are the implicit member functions of class?
What is rvalue?
Is string an object in c++?
Explain how overloading takes place in c++?
Explain linked list using c++ with an example?