Сортировать массив символов в порядке возрастания, используя сортировку Counting - PullRequest
2 голосов
/ 28 апреля 2020
Input char a[10] = {'c','b','c','d','E','C','a','A','b','C'};

Вывод: A abb C C c c de

Мне дан массив символов, и я должен отсортировать его в порядке возрастания, а я должен использовать Подсчет сортировки , чтобы сделать это

Я уже пробовал:

#include <stdio.h>
#include <stdlib.h>
#define RANGE 255


void countingSort(char a[], char b[], int n) // a = array, b = empty array, n = size
{
    int i;

    int c[RANGE +1];
    memset(c, 0, sizeof(c));


    for( i = 0; i< n; i++)
    {
        c[a[i]] = c[a[i]] + 1;
    }
    for(i = 1; i<RANGE; i++)
    {
        c[i] = c[i] + c[i-1];
    }
    for(i = n-1; i>=0; i--)
    {
        b[c[a[i]] - 1] = a[i];
        c[a[i]] = c[a[i]] - 1;
    }

}

int main()
{
    char a[10] = {'c','b','c','d','E','C','a','A','b','C'};
    int n = 10;
    char b[10];
    int i;
    for( i = 0; i<n;i++)
    {
        printf("%c",a[i]);
    }
    printf("\n");
    countingSort(a,b,n);
    for( i = 0; i<n;i++)
    {
        printf("%c",b[i]);
    }
    printf("\n");

    return 0;
}

Я использовал таблицу ASCII для сортировки массива, и мой вывод

ACCEabbccd

Мне удалось отсортировать массив в порядке возрастания, но я не знаю, как поставить сразу после A и т. Д.

1 Ответ

1 голос
/ 28 апреля 2020

Один подход просто удваивает размер c[] и формирует индекс, в котором все четные индексы прописные, а нечетные строчные.

#if 1
#define RANGE (255*2 + 1)
#include <ctype.h>
#define CH_TO_INDEX(ch) \
    (2*toupper((unsigned char)ch) + !!islower((unsigned char) ch))

#else
// Original
#define RANGE 255
#define CH_TO_INDEX(ch)    (ch)

#endif

void countingSort(char a[], char b[], int n) {
  int i;
  int c[RANGE + 1];
  memset(c, 0, sizeof(c));

  for (i = 0; i < n; i++) {
    //c[a[i]] = c[a[i]] + 1;
    c[CH_TO_INDEX(a[i])]++;
  }
  for (i = 1; i < RANGE; i++) {
    c[i] = c[i] + c[i - 1];
  }
  for (i = n - 1; i >= 0; i--) {
    // b[c[a[i]] - 1] = a[i];
    b[c[CH_TO_INDEX(a[i])] - 1] = a[i];
    // c[a[i]] = c[a[i]] - 1;
    c[CH_TO_INDEX(a[i])]--;
  }
}

Выходные данные

cbcdECaAbC
AabbCCccdE

Можно получить более сложный char --> index, который не удваивает размер c[]. Такие отображения имеют тенденцию делать предположения, что существуют только буквы AZ. Такое сопоставление может использовать вспомогательный массив сопоставления:

unsigned char map[256] - {
    0, 1, 2, ...., 31, ' ', ... 'A', 'a', 'B', 'b', ... 'Z', 'z', 
    ASCII characters after 'Z' and before 'a'
    ASCII characters after 'z', .... 255 };

Запрошен OP

Output : A a b b C C c c d e

Но на основании {'c', 'b', 'c', 'd', 'E', 'C', 'a', 'A', 'b', 'C'}, я думаю, что OP хочет

Output : A a b b C C c c d E

Обратите внимание, что оригинальный код не работает, если a[i] < 0. Код нуждается в доработке для отрицательного char. Перекодировать с помощью unsigned char.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...