ÀÛ¼ºÀÏ : 18-05-11 00:47
°ÝÀÚ»óÀÇ °æ·Î ¸Þ¸ð¸® °ú´Ù
 ±Û¾´ÀÌ : ¾çÁøÇõ(yangjh05)
Á¶È¸ : 3,108  
#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 667
¹øÈ£ Á¦   ¸ñ ±Û¾´ÀÌ ³¯Â¥ Á¶È¸
607 À۳⵵ ¿¹¼±°ú Àü±¹º»¼± Ç®ÀÌ´Â ¾ðÁ¦Âë? (1) À̹ÌÈ­ 04-01 3487
606 ÀÔ±Ý È®ÀÎ ºÎʵ右´Ï´Ù (1) ·ùÁö¹Î 03-17 3172
605 ÀÚ±âÁÖµµ C¾ð¾î °­Á½Åû (1) ŹÁø¾Æ 02-09 3552
604 °áÀç ½ÂÀÎ ¿äû (1) ½Å¹Î±Õ 02-09 3161
603 ¾Ë°í¸®Áò °­ÀÇ ½ÅûÇÒ·Á°í ÇÕ´Ï´Ù. (1) À̽ÂÅ 01-15 3502
602 ÀÔ±ÝÇß¾î¿ä (1) È«ÇõÀç 01-13 3081
601 ¼ö°­½ÅÃ»ÇØ¼­ ÀÔ±ÝÀ» Çߴµ¥ °­Àǰ¡ ¾ø¾î¿ä.. (1) È«ÇõÀç 01-12 3613
600 ÀÔ±ÝÈ®ÀÎ ºÎʵ右´Ï´Ù. (1) ±èÁø¼÷ 01-08 2817
599 ÀÚ±âÁÖµµ C¾ð¾î ÇÁ·Î±×·¡¹Ö ¹Ýº¹Á¦¾î¹®2 Çü¼ºÆò°¡ 10 (1) À̼º¿ì 12-09 4501
598 ÀÚ±âÁÖµµ c¾ð¾î ÇÁ·Î±×·¡¹Ö <ÀÔ·Â> ÀÚ°¡Áø´Ü 8¹ø Áú¹®ÀÔ´Ï¡¦ (1) Áø¼º±Ô 10-18 3400
597    ÀÚ±âÁÖµµ c¾ð¾î ÇÁ·Î±×·¡¹Ö <ÀÔ·Â> ÀÚ°¡Áø´Ü 8¹ø Áú¹®ÀÔ´Ï¡¦ ÀÌÀçÀ± 11-04 3271
596 ÀÚ±âÁÖµµ c¾ð¾î ÇÁ·Î±×·¡¹Ö <ÀÔ·Â>ÀÚ°¡Áø´Ü5¹ø Àß ¸ð¸£°Ú¡¦ (1) Áø¼º±Ô 10-18 3633
595 ÀÔ±ÝÈ®ÀÎ ºÎʵå·Á¿ä~~ Àå½ÂÇõ 10-02 2688
594 Ã¥À» ¾îµð¼­ »ç³ö¿ä? ³²ÁöÀ± 09-01 3013
593 15³â Ãʵî 4¹ø¹®Á¦ Áú¹®ÀÔ´Ï´Ù ¾È¼ºÈ£ 08-31 2890
592 µµ¿ÍÁÖ¼¼¿ä ³²ÁöÀ± 08-20 2888
591 ¸Àº¸±â ¿µ»óÀÌ Àç»ýÀÌ ¾ÈµÇ¿ä ³²ÁöÀ± 08-18 2935
590 ¹®ÀÚ¿­2 Çü¼ºÆò°¡5 ¹ø (1) Á¤ÁÖ¿µ 07-28 5044
589 ÀÚ±âÁÖµµ c¾ð¾î ÇÔ¼ö3-4¹ø ¹®Á¦ (1) ¸¸¼ö 06-19 3200
588 ÀÔ±Ý È®ÀÎ ºÎʵ右´Ï´Ù. (1) ÀÌÈ«±¹ 06-14 2918
 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