α׷

 3204, 157/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 : 4276     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  
84   ̽ å õ Ź帳ϴ[1]     dkflvkdnj
03/16 3664
83   α׷ Թ ..[1]     mwm0202
03/19 3078
  c [1]     ljh7009
03/19 4275
81   ȳϼ c++ лԴϴ[3]     axio93
03/19 3862
80   ȣ ҽڵ м.....     h@cking2013
03/24 3437
79   б Ʈ Դϴ.     rlagusgh125
03/29 2952
78   ڸ ޾ õ,,, ڸ иϿ ϴ α׷ ۼϴ¹[1]     ys9658
04/04 57839
77   ̰ ϰ Ź帳ϴ.[1]     ys9658
04/06 3381
76   ǽù Green guard α׷ ˷ ּ [1]     wqw3
04/16 4445
75   ms os °ǰ.    
04/18 3171
74   帳ϴ!     edge12
04/29 3703
73   Ŀθ忡 process Ȯϴ ֳ?     juhyun16
05/03 3705
72   c ͿñѰ ϴ. [1]     rnjsqhs1628
05/08 3370
71   C int Դϴ.[9]     suho0722
05/13 3256
70   ȳϼ ó ޴µ ڵ ϳ ɱ??     shh9547
05/14 4924
69   c programming Դϴ.[1]     alexparkjw
05/17 3588
68   [1]     gg5085
05/19 4221
67 бԴϴ  c ּФ    
05/30 2
66   ۼ cε..[5]     narasa430
06/12 3358
65   ̽ Դϴ٤̤     chdl1227
06/14 3027
[1]..[151][152][153][154][155][156] 157 [158][159][160]..[161]

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