강의로 돌아가기
GiantPark

테스트 2번의 조건이 뭘까요?

다른 테스트들은 통과했는데.. 2번을 통과하지 못했네요.. 혹시 알려주실수 있으신지
아니면 제 코드가 좀 복잡하긴 하지만 잘못된 부분이 있는지 알려주실 수 있나요?

작성중인 코드―solution.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#include <string>
#include <vector>
#include <algorithm>

using namespace std;

vector<int> solution(vector<int> progresses, vector<int> speeds) {
    vector<int> answer;
    vector<int> day(progresses.size());
    bool F = true;
    int cnt = 1;

    while(F){
        for(int i = 0; i < progresses.size(); i++){
            if(progresses[i]>=100){
                for(int j = i; j >= 0; j--){
                    if(progresses[j] < 100){
                        day[i] = day[j]+1;
                        break;
                    }
                    if(i==progresses.size()-1&&j==0){
                        F = false;
                    }
                }
            }
            else{
                progresses[i] += speeds[i];
                day[i]++;
            }
        }
    }
    sort(day.begin(),day.end());
    for(int a = 0; a < day.size(); a++){
        for(int b=a+1; b<day.size();b++){
            if(day[a]==day[b]){
                cnt++;
                day.erase(day.begin()+b);
                b--;
            }
        }
        answer.push_back(cnt);
        cnt = 1;
    }
    return answer;
}
0 개의 답변
답변 쓰기
이 입력폼은 마크다운 문법을 지원합니다. 마크다운 가이드 를 참고하세요.