최대 연속 하위 시퀀스(HDU1223)(동적 계획)
Input 테스트 입력에는 테스트 용례가 몇 개 포함되어 있으며, 각 테스트 용례는 두 줄을 차지하고, 첫 번째 줄은 정수 K (< 10000) 를 주고, 두 번째 줄은 K 개의 정수를 주며, 중간은 빈칸으로 구분한다.K가 0일 때 입력이 끝났습니다. 이 용례는 처리되지 않습니다.
Output은 모든 테스트 용례에 대해 1줄에서 최대, 최대 연속 서열의 첫 번째 요소와 마지막 요소를 출력하고, 중간에 빈칸으로 구분합니다.최대 연속 서열이 유일하지 않으면, 번호 i와 j의 가장 작은 것을 출력합니다. (예를 들어 예시를 입력한 2, 3조)모든 K 요소가 음수이면 최대 및 0을 정의하여 전체 시퀀스의 첫 번째 끝 요소를 출력합니다.
Sample Input6-2 11 -4 13 -5 -210-10 1 2 3 4 -5 -23 3 7 -2165 -8 3 2 5 01103-1 -5 -23-1 0 -20
Sample Output20 11 1310 1 410 3 510 10 100 -1 -20 0 0
#include
#include
using namespace std;
const int N= 10000;
int a[N], dp[N], maxsum, maxstart, maxend;
void serach(int n)
{
int sum, sumstart;
maxsum = maxstart = maxend = a[0];
sum = 0;
for(int i = 0; i maxsum)
{
maxsum = sum;
maxstart = sumstart;
maxend = a[i];
}
}
}
int main()
{
int n;
while(cin>>n&& n)
{
for(int i=0; i>a[i];
serach(n);
if(maxsum < 0)
cout<
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.