제가 푼 방식이 시간이 좀 오래 걸리는 것 같아 질문합니다.
안녕하세요!
제가 queue와 구조체를 이용해 문제를 풀었는데 1초가 넘게 걸려서 무엇이 문제인지 질문합니다
queue의 push, pop은 O(1)이라고 알고 있는데도 이렇게 오래 걸려서..제가 유추하기로는 구조체를 썼기 때문인 것 같은데...만약 그렇다면 왜 그런 것인가요...?
코드 아래 첨부합니다.
#include<cstdio>
using namespace std;
#include<vector>
#include<algorithm>
#include<string>
#include<queue>
int main(void)
{
//cin.tie(NULL); // 얘네 3줄은 iostream include했을 때 필요한 것.
//cout.tie(NULL);
//ios::sync_with_stdio(false);
freopen("in4.txt", "rt", stdin); // 파일 입력받음
struct NumWork
{
int work; // 작업 번호
int t; // 작업 시간
};
int n, k;
scanf("%d", &n);
queue<NumWork> work;
for (int i = 0; i < n; i++)
{
int tmp;
scanf("%d", &tmp);
work.push(NumWork{ i + 1, tmp });
}
scanf("%d", &k);
int time = 0; // 총 시간
while (work.empty() == false)
{
if (time == k) // 만약 k초면 break;
break;
NumWork now = work.front();
work.pop();
time++; // 시간은 언제나 흐르므로 ++
if (now.t - 1 == 0) // 작업시간이 0됐으면 다시 queue에 넣지 않음
continue;
work.push(NumWork{ now.work, now.t - 1 });
}
if (work.empty()) // work가 empty면 모든 작업이 k이전에 끝난 것
printf("-1");
else // empty가 아니면 k초 이후에 작업이 남아있었음
printf("%d", work.front().work);
}
답변 1
87번 채점 프로그램에 오류가 있는 것 같습니다.
0
91
2
그리디 파트
0
115
2
안녕하세요. 선생님(54번 코드 관련 문의)
0
143
2
테스트 파일 exit_coe_1, time_limit_exceeded 질문
0
143
1
C언어로 코드를 짜면 채점 시에 한 문제 빼고 시간 초과가 발생하는데 해결하는 방법이 있을까요?
0
173
1
19번 질문있습니다
0
123
1
6번 관련 채점오류입니다
0
88
2
22번 문제는 C로 풀어주신 건가요 C++로 풀어주신 건가요?
0
166
2
dev C++ 콘솔창 바로 닫힘
0
245
1
최신화하기
0
171
1
채점이 안되요...
1
261
1
안녕하세요 강사님 정렬에 대해서 설명이 조금 더 듣고 싶습니다.
0
113
1
45번 공주구하기 문제를 list를 이용해서 이렇게 풀어도 될까요?
0
155
1
39번 두 배열 합치기 문제 채점 오류인가 코드 오류인가
0
155
0
채점기에서 틀렸다고 나오는데 이유를 모르겠습니다.
0
150
2
해당 강의에서 C언어로만 진행하는 강의 문의 건
0
145
2
87번 문제 섬나라 아일랜드 질문
0
128
1
16번 문제에서 직접 답을 대입하면 정답이 나오는데 채점에서 wrong answer가 나옵니다.
0
149
1
40번 교집합 문제
0
166
1
43번 뮤직비디오 문제 테스트케이스 4번을 만족 못합니다.
0
170
1
41. 연속된 자연수의 합 문제 질문있습니다.
0
166
1
질문있습니다.
0
193
2
시간초과가 나요
0
172
1
43번 문제 3 ~ 5번에 문제가 있는것 같습니다.
0
249
1





