작성일 : 18-05-11 00:47
격자상의 경로 메모리 과다
 글쓴이 : 양진혁(yangjh05)
조회 : 599  
#include <stdio.h>
#include <algorithm>

using namespace std;

double f(int a){
    if(a == 0) return 1;
    return a*f(a - 1);
}

int main()
{
    int N, M, K;
    double ans;
    scanf("%d %d %d", &N, &M, &K);
    if(K == 0){
        ans = f(N + M - 2) / (f(N - 1) * f(M - 1));
        printf("%d", (int)ans);
    } else {
        int x, y;
        y = (K / M) + 1;
        x = K - M * (y - 1);
        ans = (double)((f(x + y - 2) / (f(x - 1) * f(y - 1))) * (f(M + N - x - y) / (f(M - x) * f(N - y))));
        printf("%d", (int)ans);
    }
    return 0;
}
메모리 과다가 어디서 일어나는지 알고 싶어요. 실제 프로그램은 33KB던데...

양진혁 18-05-11 01:21
 
#include <stdio.h>

int D[40][40];
int x, y;
int N, M, K, ans;

int way(int fx, int fy){
    if(fx == 1 || fy == 1) return 1;
    if(fy > N || fx > M) return 0;
    if(D[fx][fy]) return D[fx][fy];
    return D[fx][fy] = way(fx - 1, fy) + way(fx, fy - 1);
}

int main()
{
    scanf("%d %d %d", &N, &M, &K);
    if(K == 0) ans = way(M, N);
    else {
        double tmp;
        tmp = (double)K / (double)M;
        if(tmp - (int)(K / M) > 0) y = (K / M) + 1;
        else y = K / M;
        x = K - M * (y - 1);
        ans = way(x, y) * way(M - x + 1, N - y + 1);
    }
    printf("%d", ans);
    return 0;
}
이게 제대로 된 답인데... 그것도 맞지 않나요...?
컴스쿨 18-05-17 14:22
 
아래의 프로그램중

 if(D[fx][fy]) return D[fx][fy];

이 부분을 보면 해당 위치에 이미 호출해서 값이 구해진 기록이 있으면 다시 호출하지 않습니다.

하지만 위의 코드는 같은 위치를 계속 반복해서 호출을 하게 되므로 스택메모리 공간이 부족하게 됩니다.
 
 

Total 616
번호 제   목 글쓴이 날짜 조회
616 배열1에서 자가진단7 김세연 11-01 82
615 결재했습니다 김성희 10-30 101
614 2019년 문제풀이 올려주세요. (내용무) 박중수 10-27 91
613 결제 문의 한지현 10-05 127
612 방금 입금했습니다. 정민정 08-23 204
611 혹시 2008년 본선 중5 평면도 문제 풀이 올라 왔나요? (1) 이민 06-11 346
610 수강승인부탁드립니다. (1) 백현민 05-10 326
609 승인바랍니다.입금완료. (1) 이재준 04-19 394
608 작년도 예선과 전국본선 풀이는 언제쯤? (1) 이미화 04-01 491
607 입금 확인 부탁드립니다 (1) 류지민 03-17 406
606 자기주도 C언어 강좌신청 (1) 탁진아 02-09 545
605 결재 승인 요청 (1) 신민균 02-09 427
604 알고리즘 강의 신청할려고 합니다. (1) 이승태 01-15 552
603 입금했어요 (1) 홍혁재 01-13 428
602 수강신청해서 입금을 했는데 강의가 없어요.. (1) 홍혁재 01-12 926
601 입금확인 부탁드립니다. (1) 김진숙 01-08 377
600 자기주도 C언어 프로그래밍 반복제어문2 형성평가 10 (1) 이성우 12-09 752
599 자기주도 c언어 프로그래밍 <입력> 자가진단 8번 질문입니… (1) 진성규 10-18 584
598    자기주도 c언어 프로그래밍 <입력> 자가진단 8번 질문입니… 이재윤 11-04 600
597 자기주도 c언어 프로그래밍 <입력>자가진단5번 잘 모르겠… (1) 진성규 10-18 473
 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    

회사소개 | 개인정보처리방침 | 이용약관 | 찾아오시는 길 | 이메일주소 무단수집거부 | 사업자정보확인
경기도 안양시 동안구 호계동 1065-10 협성골드프라자 601호 한컴에듀케이션(주) TEL : 031-388-8840 FAX : 031-388-0996
대표자 : 김동규 사업자번호 : 130-86-02870 통신판매업신고번호 : 제 2010-경기안양-888호
COPYTIGHT(C) 한컴에듀케이션(주), ALL RIGHT RESERVED.
담은강좌 : 0