문제 설명
초 단위로 기록된 주식가격이 담긴 배열 prices가 매개변수로 주어질 때, 가격이 떨어지지 않은 기간은 몇 초인지를 return 하도록 solution 함수를 완성하세요.
제한사항
  • prices의 각 가격은 1 이상 10,000 이하인 자연수입니다.
  • prices의 길이는 2 이상 100,000 이하입니다.

  • 소스코드 :
#include <iostream>
#include <vector>

using namespace std;

vector<int> solution(vector<int> prices) {
    vector<int> answer;
    vector<int> tmp;
    vector<int> last;

    for(int i = 0; i < prices.size(); i++)
        answer.push_back(prices[i]);
    
    for(int i = 0; i < answer.size(); i++)
    {
        int sum = 0;
        for(int j = i; j < answer.size()-1; j++)
        {   
            if(prices[i] <= prices[j]) sum++; //감소하는 경우도 첫번째 순환에서 처리된다.
            else break;
        }     
        tmp.push_back(sum);
    }
    
    tmp.pop_back();
    tmp.push_back(0);

    for(int i = 0; i < tmp.size(); i++)
    {
        last.push_back(tmp[i]);
    }
    
    return last;
}

카테고리:

업데이트:

댓글남기기