Maximum circular sum

Please check my code

#include
#include <bits/stdc++.h>
using namespace std;
int main(){
int n;
cin>>n;
int a[1000]={0};
int max_sum[1000]={0};
int final_sum=INT_MIN;

for (int i=0;i<n;i++){
	cin>>a[i];
}

int p=0;
int q=n;
int c=0;
while (p!=n){
	int sum=0;
	int cumulative_sum[1000]={0};
	int max_element=INT_MIN;
	for (int i=p;i<q;i++){
		sum+=a[i];
		cumulative_sum[i]=sum;
	}
	for(int i=0;i<n;i++){
		max_element=max(cumulative_sum[i],max_element);
	}
	max_sum[c]=max_element;
	a[q]=a[p];
	c++;
	p++;
	q++;
}
for (int i=0;i<n;i++){
	final_sum=max(max_sum[i],final_sum);
}
cout<<final_sum<<endl;
return 0;

}