답안 #2150

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
2150 2013-07-20T05:34:47 Z mhkim4886 생일수 I (GA4_birthday1) C++
14 / 100
0 ms 1668 KB
#include <stdio.h>

typedef struct _Num
{
    int num;
    int total;
} Num;

int out[101], n, qrear = 1, qtail = 1;
Num que[100001];

int main()
{
    scanf("%d", &n);

    for(int i = 1; i <= n; i++)
    {
        int k;
        scanf("%d", &k);

        qrear = 1;
        qtail = 1;
        que[qtail].num = que[qtail++].total = 3;
        que[qtail].num = que[qtail++].total = 5;
        que[qtail].num = que[qtail++].total = 8;

        while(true)
        {
            int q = que[qrear++].total;
            if(q == k)
            {
                out[i] = que[qrear-1].num;
                break;
            }
            else
            {
                if(que[qrear-1].total + 3 <= k)
                {
                    que[qtail].num = que[qrear-1].num * 10 + 3;
                    que[qtail++].total = que[qrear-1].total + 3;
                }
                if(que[qrear-1].total + 5 <= k)
                {
                    que[qtail].num = que[qrear-1].num * 10 + 5;
                    que[qtail++].total = que[qrear-1].total + 5;
                }
                if(que[qrear-1].total + 8 <= k)
                {
                    que[qtail].num = que[qrear-1].num * 10 + 8;
                    que[qtail++].total = que[qrear-1].total + 8;
                }
            }

            if(qrear == qtail)
            {
                out[i] = -1;
                break;
            }
        }
    }

    for(int i = 1; i <= n; i++) printf("%d\n", out[i]);
}
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 1668 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Runtime error 0 ms 1664 KB SIGSEGV Segmentation fault
# 결과 실행 시간 메모리 Grader output
1 Runtime error 0 ms 1664 KB SIGSEGV Segmentation fault
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Runtime error 0 ms 1664 KB SIGSEGV Segmentation fault
2 Halted 0 ms 0 KB -