New
This commit is contained in:
		
							
								
								
									
										43
									
								
								Exercise/Extra/最大连续子序列.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								Exercise/Extra/最大连续子序列.cpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,43 @@
 | 
				
			|||||||
 | 
					#include <iostream>
 | 
				
			||||||
 | 
					#include <vector>
 | 
				
			||||||
 | 
					using namespace std;
 | 
				
			||||||
 | 
					int main(){
 | 
				
			||||||
 | 
						int n;
 | 
				
			||||||
 | 
						cin >> n;
 | 
				
			||||||
 | 
						vector<int> arr(n), dp(n);
 | 
				
			||||||
 | 
						for(int i = 0; i < n; i++){
 | 
				
			||||||
 | 
							cin >> arr[i];
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						dp[0] = arr[0];
 | 
				
			||||||
 | 
						int smax = -1;
 | 
				
			||||||
 | 
						bool hasans = false;
 | 
				
			||||||
 | 
						for(int i = 1; i < n; i++){
 | 
				
			||||||
 | 
							dp[i] = max(dp[i - 1] + arr[i], arr[i]);
 | 
				
			||||||
 | 
							if(dp[i] >= 0) hasans = true;
 | 
				
			||||||
 | 
							if(dp[i] > smax) smax = dp[i];
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if(!hasans){
 | 
				
			||||||
 | 
							cout << "0" << endl; 
 | 
				
			||||||
 | 
							cout << "-1" << " " << "-1" << endl;
 | 
				
			||||||
 | 
							return 0;
 | 
				
			||||||
 | 
						} else{
 | 
				
			||||||
 | 
							int js = -1;
 | 
				
			||||||
 | 
							for(int i = 0; i < n; i++){
 | 
				
			||||||
 | 
								if(dp[i] == smax) {
 | 
				
			||||||
 | 
									js = i;
 | 
				
			||||||
 | 
									break;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							int sum = 0;
 | 
				
			||||||
 | 
							for(int i = js; i >= 0; i--){
 | 
				
			||||||
 | 
								sum += arr[i];
 | 
				
			||||||
 | 
								if(sum == smax){
 | 
				
			||||||
 | 
									sum = i;
 | 
				
			||||||
 | 
									cout << smax << endl;
 | 
				
			||||||
 | 
									cout << sum << " " << js << endl;
 | 
				
			||||||
 | 
									return 0;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
		Reference in New Issue
	
	Block a user