Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,870 questions

51,793 answers

573 users

How to sort an array of numeric strings in ascending order with C

2 Answers

0 votes
#include <stdio.h>
#include <stdlib.h>

int compare(const void* a, const void* b) {
    return (*(int*)a - *(int*)b);
}

int main()
{
    const char* arr_string[] = { "7", "0", "55", "8", "9", "6" };
    int arr_int[] = { 0, 0, 0, 0, 0, 0 };

    int size = sizeof(arr_string) / sizeof(arr_string[0]);

    for (int i = 0; i < size; i++) {
        arr_int[i] = atoi(arr_string[i]);
    }

    qsort(arr_int, size, sizeof(int), compare);

    for (int i = 0; i < size; i++) {
        printf("%d ", arr_int[i]);
    }

    return 0;
}




/*
run:

0 6 7 8 9 55

*/

 



answered Sep 3, 2022 by avibootz
0 votes
#include <stdio.h>
#include <stdlib.h>

int compare(const void* a, const void* b) {
    return (*(long*)a - *(long*)b);
}

int main()
{
    const char* arr_string[] = { "7", "0", "55", "8", "9", "6" };
    long arr_long[] = { 0, 0, 0, 0, 0, 0 };

    int size = sizeof(arr_string) / sizeof(arr_string[0]);

    for (int i = 0; i < size; i++) {
        arr_long[i] = (int)strtol(arr_string[i], (char**)NULL, 10);
    }

    qsort(arr_long, size, sizeof(long), compare);

    for (int i = 0; i < size; i++) {
        printf("%ld ", arr_long[i]);
    }

    return 0;
}




/*
run:

0 6 7 8 9 55

*/

 



answered Sep 3, 2022 by avibootz

Related questions

...