1. Си / Говнокод #21642

    −25

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    /**
      * Сортирует массив, используя рекурсивную сортировку слиянием
      * up - указатель на массив, который нужно сортировать
      * down - указатель на массив с, как минимум, таким же размером как у 'up', используется как буфер
      * left - левая граница массива, передайте 0, чтобы сортировать массив с начала
      * right - правая граница массива, передайте длину массива - 1, чтобы сортировать массив до последнего элемента
      * возвращает: указатель на отсортированный массив. Из-за особенностей работы данной реализации
      * отсортированная версия массива может оказаться либо в 'up', либо в 'down' // <--- ГОВНО
      **/
    int* merge_sort(int *up, int *down, unsigned int left, unsigned int right)
    {
        if (left == right)
        {
            down[left] = up[left];
            return down;
        }
    
        unsigned int middle = (unsigned int)((left + right) * 0.5); // <--- ГОВНО, нахуй сюда плавучих питухов пихать?
        // И что еще за unsigned int? Даешь uintptr_t.
        // И если указатели будут 64-битные, то плавучий питух может обосраться на больном размере массивов
    
        // разделяй и сортируй
        int *l_buff = merge_sort(up, down, left, middle);
        int *r_buff = merge_sort(up, down, middle + 1, right);
    
        // слияние двух отсортированных половин
        int *target = l_buff == up ? down : up;
    
        unsigned int width = right - left, l_cur = left, r_cur = middle + 1;
        for (unsigned int i = left; i <= right; i++)
        {
            if (l_cur <= middle && r_cur <= right)
            {
                if (l_buff[l_cur] < r_buff[r_cur])
                {
                    target[i] = l_buff[l_cur];
                    l_cur++;
                }
                else
                {
                    target[i] = r_buff[r_cur];
                    r_cur++;
                }
            }
            else if (l_cur <= middle)
            {
                target[i] = l_buff[l_cur];
                l_cur++;
            }
            else
            {
                target[i] = r_buff[r_cur];
                r_cur++;
            }
        }
        return target;
    }

    https://ru.wikipedia.org/wiki/Сортировка_слиянием

    Запостил: j123123, 05 Ноября 2016

    Комментарии (17) RSS

    Добавить комментарий