Advertisement
Guest User

Untitled

a guest
Feb 26th, 2020
90
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 2.70 KB | None | 0 0
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <ctype.h>
  4. #include <string.h>
  5. #include <wctype.h>
  6. #include <wchar.h>
  7. #include <errno.h>
  8. #include <locale.h>
  9.  
  10.  
  11. int comp(const void * a, const void * b, void * it) {
  12.     int arg1 = *((const int*)a);
  13.     int arg2 = *((const int*)b);
  14.     wchar_t * m = (wchar_t *)it;
  15.  
  16.     wchar_t * one = (wchar_t *) malloc(sizeof(wchar_t));
  17.     wchar_t * two = (wchar_t *) malloc(sizeof(wchar_t));
  18.     int size_one = 1;
  19.     int size_two = 1;
  20.  
  21.     int i = arg1;
  22.     while (m[i] != WCHAR_MAX) {
  23.         one[size_one - 1] = m[i];
  24.         one = (wchar_t *) realloc(one, (size_one + 1) * sizeof(wchar_t));
  25.         ++size_one;
  26.         ++i;
  27.     }
  28.  
  29.     one[size_one - 1] = m[i];
  30.     one = (wchar_t *) realloc(one, (size_one + 1) * sizeof(wchar_t));
  31.     ++size_one;
  32.  
  33.     i = 0;
  34.     while (i != arg1) {
  35.         one[size_one - 1] = m[i];
  36.         one = (wchar_t *) realloc(one, (size_one + 1) * sizeof(wchar_t));
  37.         ++size_one;
  38.         ++i;
  39.     }
  40.  
  41.     int j = arg2;
  42.     while (m[j] != WCHAR_MAX) {
  43.         two[size_two - 1] = m[j];
  44.         two = (wchar_t *) realloc(two, (size_two + 1) * sizeof(wchar_t));
  45.         ++size_two;
  46.         ++j;
  47.     }
  48.  
  49.     two[size_two - 1] = m[j];
  50.     two = (wchar_t *) realloc(two, (size_two + 1) * sizeof(wchar_t));
  51.     ++size_two;
  52.  
  53.     j = 0;
  54.     while (j != arg2) {
  55.         two[size_two - 1] = m[j];
  56.         two = (wchar_t *) realloc(two, (size_two + 1) * sizeof(wchar_t));
  57.         ++size_two;
  58.         ++j;
  59.     }
  60.  
  61.     one[size_one] = '\0';
  62.     two[size_two] = '\0';
  63.  
  64.     int ans = wcscmp(two, one);
  65.  
  66.     free(one);
  67.     free(two);
  68.  
  69.     return ans;
  70. }
  71.  
  72. int main() {
  73.     setlocale(LC_ALL, "");
  74.     wint_t cur = 0;
  75.     wchar_t * vec_w = (wchar_t *) malloc(sizeof(wchar_t));
  76.     int * real = (int *) malloc(sizeof(int));
  77.     int size = 0;
  78.  
  79.     int i = 0;
  80.     while ((cur = getwchar()) != WEOF && cur != '2') {
  81.         if (!isspace(cur)) {
  82.             vec_w[i] = cur;
  83.             real[i] = i;
  84.             ++i;
  85.             if (i >= size) {
  86.                 vec_w = (wchar_t *) realloc(vec_w, (size + 1) * sizeof(wchar_t));
  87.                 real = (int *) realloc(real, (size + 1) * sizeof(int));
  88.                 ++size;
  89.             }
  90.         }
  91.     }
  92.     vec_w[size - 1] = WCHAR_MAX;
  93.     real[size - 1] = size - 1;
  94.  
  95.     qsort_r(real, size, sizeof(int), comp, vec_w);
  96.  
  97. //    for (int k = 0; k < size; ++k) {
  98. //        printf("%d\t", real[k]);
  99. //    }
  100. //    printf("\n");
  101.  
  102.  
  103.     for (int k = 0; k < size; ++k) {
  104.         if (real[k] == 0) {
  105.             putwchar('#');
  106.         } else {
  107.             putwchar(vec_w[real[k - 1]]);
  108.         }
  109.     }
  110.     printf("\n");
  111.     free(vec_w);
  112.     free(real);
  113. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement