ÇÁ·Î±×·¡¹Ö

 3206, 1/161 ȸ¿ø°¡ÀÔ  ·Î±×ÀΠ 
   ljh7009
   c¾ð¾î »ðÀÔ Á¤·Ä Áß °£Á¢Á¤·Ä Áú¹®µå·Á¿ä

http://www.hackerschool.org/HS_Boards/zboard.php?id=QNA_programming&no=6518 [º¹»ç]


ÀüüÀûÀÎ ¼Ò½º´Â

#include <stdio.h>
#include <malloc.h>

void indirect_insert_sort(int a[], int index[], int n)
{
        int i, j;
        int t;

        for(i = 0; i < n; i++)
                index[i] = i;

        for(i = 1; i< n; i++)
        {
                t = index[i];
                j = i;

                while(a[index[j-1]] > a[t] && j > 0)        
                {                                    
                        index[j] = index[j-1];
                        j--;
                }

                index[j] = t;
        }
}

void rearrange(int a[], int index[], int n)
{
        int *p;
        int i;
        p = (int*)malloc(sizeof(int) * n);

        for(i = 0; i < n; i++)
                p[i] = a[index[i]];

        for(i = 0; i < n; i++)
                a[i] = p[i];

        free(p);
}

void print_arr(int a[], int n)
{
        int i;

        for(i = 0; i < n; i++)
                printf("%-5d", a[i]);

        printf("\n");
}

void print_index_arr(int a[], int index[], int n)
{
        int i;

        for(i = 0; i < n; i++)
                printf("%-5d", a[index[i]]);

        printf("\n");
}

int main()
{
        int arr[] = {9, 8, 7, 6, 5, 4, 3, 2, 1};
        int len = sizeof(arr) / sizeof(int);
        int index[sizeof(arr) / sizeof(int)] = {0, };

        printf("ÃʱⰪ\n");
        print_arr(arr, len);
        
        indirect_insert_sort(arr, index, len);

        printf("\n°£Á¢ Á¤·Ä ÈÄ arr °ª\n");
        print_arr(arr, len);

        printf("\n°£Á¢ Á¤·Ä ÈÄ arr[index] °ª\n");
        print_index_arr(arr, index, len);

        rearrange(arr, index, len);

        printf("\n°£Á¢ Á¤·Ä, Àç¹è¿­ ÈÄ arr°ª\n");
        print_arr(arr, len);

        return 0;
}

ÀÌ°ÍÀÔ´Ï´Ù.

ÀÌ Áß¿¡ ÄÄÆÄÀÏ ½Ã indirect_insert_sort ÇÔ¼öÀÇ

while(a[index[j-1]] > a[t] && j > 0) ºÎºÐÀÌ ¿¡·¯°¡ ³³´Ï´Ù.

±Ùµ¥ Á¶°Ç ¼ø¼­¸¦ while(j > 0 && a[index[j-1]] > a[t]) ·Î ¹Ù²Ù¸é

¿¡·¯°¡ ³ªÁö ¾Ê½À´Ï´Ù... ÀÌÀ¯¸¦ ¾Ë·ÁÁÖ½Ç ¼ö ÀÖ³ª¿ä??

  Hit : 4253     Date : 2015/03/19 06:22



    
Prox while(j > 0 && a[index[j-1]] > a[t]) ÀÌ°Ô ¸Â´Â ÄÚµùÀÔ´Ï´Ù.

c¾ð¾îÀÇ &&³ª || ¿¬»êÀÚ´Â °è»ê½Ã¿¡ short-circuit evaluationÀ» ÇÕ´Ï´Ù
½±°Ô¸»Çϸé a&&b ÀÇ °æ¿ì, a°¡ °ÅÁþÀ̸é b¸¦ °è»êÇÏÁö ¾Ê°í ¹Ù·Î false·Î ó¸®Çϴ°̴ϴÙ
±×·¡¼­ j>0°°Àº À妽º °Ë»ç´Â &&ÀÇ ¿ÞÂÊ¿¡ ³Ö¾î¾ßÇÕ´Ï´Ù

while(a[index[j-1]] > a[t] && j > 0) °°Àº°æ¿ì¿¡´Â...
j=0À϶§ ¸ÕÀú index[j-1]=index[-1]ÀÇ °ªÀ» Àоî¿À°ÚÁÒ? ¾Æ¸¶ -123456°°Àº dummy°ªÀÌ ÀÐÈ÷°ÚÁÒ
±×¸®°í ´Ù½Ã a[-123456] ó·³ Á¢±ÙÇϸé... ¸Å¿ì ³ôÀº È®·ü·Î access violationÀÌ ¹ß»ýÇÒ °Ì´Ï´Ù
2015/03/20  
3206   SNSÇØÅ·ÀÌ µÇ³ª¿ë? µµ¿ÍÁÖ¼¼¿ä ¤Ð¤Ð¤Ð [2]     ÇÑä¹Î
02/28 335
3205   Ä¡Æ®¿£Áø °í¼öºÐ °è½Ç±î¿ä[1]     rjsdudals123
02/15 188
3204   ¿À·ù Á» ã¾ÆÁÖ¼¼¿ä [1]     marunim
05/30 921
3203 ºñ¹Ð±ÛÀÔ´Ï´Ù  124     minsub87
08/17 1
3202   c¾ð¾î segmentation fault:11 ¿À·ù Áú¹®µå¸³´Ï´Ù![2]     leebk1124
05/21 2008
3201   C++ÇÔ¼ö°ü·Ã Áú¹®ÀÌ¿¡¿ë!![3]     1999dylee
05/11 1843
3200   ÆÄÀ̽ã Áö¹® µå¸³´Ï´Ù.[1]     kksh1107
04/24 1583
3199   ¸®¹ö½ÌÀÇ ¼¼¹ø¤Š ²É - ¿ª¶û-     nninni79
04/20 2287
3198   ´Þ°í³ª ¹®¼­ ½©ÄÚµå[1]     ghjk645
03/24 1605
3197 ºñ¹Ð±ÛÀÔ´Ï´Ù  c¾ð¾î ¼Ò¼ö °ª     adwefq
04/29 0
3196   C¾ð¾î ¼Ò½ºÁú¹®ÀÔ´Ï´Ù![5]     an0088
01/05 5120
3195   C++ /// ºôµå ¿¡·¯ ¤Ð¤Ð[1]     guichanta
08/23 2396
3194 ºñ¹Ð±ÛÀÔ´Ï´Ù  c¾ð¾î µµ¿ÍÁÖ¼¼¿ä¤Ð¤Ð     su6339
04/06 0
3193   ÇØÅ·À» ¹è¿ì·Á°íÇϴµ¥[3]     zoodem04
03/26 4180
3192   c¾ð¾î¸¦ ¹è¿ì°í½Í¾î¿ä ![7]     dwc07238
02/11 4063
3191   ½ºÅÃÀÌ ½×ÀÌ´Â ¹æÇâ¿¡ °üÇؼ­!![1]     hackxx123
12/10 3514
3190   ÇØÅ·Åø¿¡¼­ ip ¾øÀÌ Çϵ忡 ½É´Â°Å¿¡´Â ¾î¶²°Ô ÀÖÀ»±î¿ä?[2]     aowlrgmlals
11/27 4275
3189   C¾ð¾î Çϴµ¥ double ½Ç¼ö¸¦ ³ÖÀºµ¥ ÀÚ²Ù 0.0ÀÌ ³ª¿Í¿ä[2]     fatou10336
11/20 3727
3188   dumpcode.h ÀÌÇØÁ» µµ¿ÍÁÖ¼¼¿ä .[1]     cm6418
11/06 3704
3187   c¾ð¾î ¾Ë°í¸®Áò Áú¹®ÀÔ´Ï´Ù.[3]     alstn8150
10/12 3731
1 [2][3][4][5][6][7][8][9][10]..[161]

Copyright 1999-2024 Zeroboard / skin by Hackerschool.org / Secure Patch by Hackerschool.org