Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.92
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
#1

работа с функцией qsort - C++

20.12.2011, 17:44. Просмотров 1497. Ответов 32
Метки нет (Все метки)

вот есть код который отделает слова и записывает в массив и надо их отсортировать по возрастанию длины как использовать qsort в данном случае?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#include <iostream>
using namespace std;
 
 
 
void main()
{
 
char div[] = "(){}[]<>;\"=+-*., ";
char*text,*s1,*s2;
text=new char[30];
s1=new char[30];
s2=new char[30];
 char *mas[30];
     int mac[30];    
        char s[486]="So she was considering in her own mind, as well as she could, for the hot day made her feel very sleepy and stupid,  whether  the  pleasure  of making a daisy-chain would be worth the trouble of getting up and  picking the daisies, when suddenly a White Rabbit with pink eyes ran close by her.";
        cout<<"Enter string: ";
        unsigned int a,i=0;
        a=0;
        int arrCount[255];
        int ind=0;
        s1=strtok(s,div);
     while (s1!=NULL)
     {
          mas[i]=new char[30];
          strcpy(mas[i],s1);
          mac[i]=strlen(s1);
          i++;
          s1=new char[30];
          s1=strtok(NULL,div);
     }
//qsotr(
 system("pause");
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.12.2011, 17:44
Здравствуйте! Я подобрал для вас темы с ответами на вопрос работа с функцией qsort (C++):

задание с функцией qsort(). язык C - C++
задание: составить программу, которая обрабатывает следущие данные про наличие вычислительной техники: название подраздела, название...

Пожскажите с функцией sort() или qsort() - C++
Есть программа, которая генерирует случайно 10 неповторяющихся чисел от 1 до 10 и записывает их в массив array, вот код: ...

Возникли трудности с функцией быстрой сортировки qsort - C++
Добрый вечер. Есть массив прямоугольников со своей высотой и шириной, надо отсортировать отдельно по высоте, ширине и площади...

Работа функции qsort - объяснить работу функции - C++
#include&lt;iostream&gt; #include&lt;cstdlib&gt; int mysort(const void *arg1, const void *arg2); int main() { const short ARR_SIZE=5; int...

Работа с функцией - C++
Привет Всем!!! Помогите пожалуйста. Нужно: Определить функцию, которая возвращает натуральное число, если аргумент функции является...

Работа с функцией - C++

32
go
Эксперт С++
3586 / 1366 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
20.12.2011, 21:49 #16
Цитата Сообщение от OstapBender Посмотреть сообщение
да, я ошибся с размером, надо 3-м параметром - 4.
Опять ошиблись, размер указателя варьируется и зависит от системы!
Без sizeof никак, да и признак дурного тона его не использовать, даже если вы пишете программу в студии. Код должен быть переносимым...
C
1
sizeof (char *);
или лучше
C
1
sizeof (arr[0]);
0
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
20.12.2011, 21:52  [ТС] #17
а поможете исправить ошибку ?
0
OstapBender
584 / 523 / 35
Регистрация: 22.03.2011
Сообщений: 1,585
20.12.2011, 21:57 #18
go, придирки
sergeu90, мой код работает!
0
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
20.12.2011, 21:57  [ТС] #19
можете его скинуть уже работающий весь что бы выводило строки а то у меня вывода не было в моем коде не мог вывести пожалуйста
0
OstapBender
584 / 523 / 35
Регистрация: 22.03.2011
Сообщений: 1,585
20.12.2011, 21:58 #20
C
1
2
3
4
5
    qsort(mas,i,4,cmp);
 
    for (int k=0; k<i; k++) {
        puts(mas[k]);
    }
0
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
20.12.2011, 22:00  [ТС] #21
оно выводит не отсортированно по длине
0
OstapBender
584 / 523 / 35
Регистрация: 22.03.2011
Сообщений: 1,585
20.12.2011, 22:03 #22
надо изменить 1 строчку
0
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
20.12.2011, 22:03  [ТС] #23
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#include <iostream>
using namespace std;
int cmp(const void* a, const void* b) {
return strcmp(*(char**)a,*(char**)b);
}
void main()
{
 
char div[] = "(){}[]<>;\"=+-*., ";
char*text,*s1,*s2;
text=new char[30];
s1=new char[30];
s2=new char[30];
 char *mas[10];
     int mac[30];    
        char s[486]="So she was considering in her own mind, as we";
        //cout<<"Enter string: ";
       int a,i=0;
        a=0;
        int arrCount[255];
        int ind=0;
        s1=strtok(s,div);
     while (s1!=NULL)
     {
         mas[i]=new char[30];
         strcpy(mas[i],s1);
         mac[i]=strlen(s1);
         i++;
         s1=new char[30];
         s1=strtok(NULL,div);
     }
 
qsort(mas,i,4,cmp);
 
        for (int k=0; k<i; k++) 
        {
                puts(mas[k]);
        }
 
 system("pause");
}
вот код что тут надо изменить не понимаю
0
OstapBender
584 / 523 / 35
Регистрация: 22.03.2011
Сообщений: 1,585
20.12.2011, 22:07 #24
ну будь добр подумай немножко
0
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
20.12.2011, 22:08  [ТС] #25
да уже день ломаю голову не могу понять про какие три буквы имете ввиду
0
OstapBender
584 / 523 / 35
Регистрация: 22.03.2011
Сообщений: 1,585
20.12.2011, 22:08 #26
ну и всё таки как было сказано измени уж 4 на sizeof(mas[0])

про 3 буквы я уже стер.
0
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
20.12.2011, 22:09  [ТС] #27
все равно не выводит отсортировано просто вывоводит слова
0
go
Эксперт С++
3586 / 1366 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
20.12.2011, 22:13 #28
sergeu90, ну а толку то
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
#define DELIM " \t\n"
 
int cmp (const void *a, const void*b) { return strcmp ( *(char **)a, *(char **)b) ; }
 
int main(void)
{
    char *buf[BUFSIZ], s[BUFSIZ] = "Hello world world hello", *p;
    size_t i, cnt = 0;
 
    p = strtok (s, DELIM);
 
    while ( p )
    {
        buf[cnt++] = strdup ( p );
        p = strtok (NULL, DELIM);
    }
 
    qsort (buf, cnt, sizeof (char*), cmp); 
 
    for ( i = 0 ; i < cnt ; ++i)
    {
        printf ("\n %s", buf[i]);
        free (buf[i]);
    }
 
    system ("pause");
    return 0;
}
0
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
20.12.2011, 22:14  [ТС] #29
этот код тоже не выводит в порядке возрастания слова
0
go
Эксперт С++
3586 / 1366 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
20.12.2011, 22:15 #30
sergeu90, http://liveworkspace.org/code/263a3c8d6cd8a51e61b05a122cc4d7c6
0
20.12.2011, 22:15
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
20.12.2011, 22:15
Привет! Вот еще темы с ответами:

Работа с функцией - C++
Описать функцию smooth(A,n), заменяющую каждый элемент вещественного массива A размера n на его среднее арифметическое со своими соседями...

работа с функцией в С++ - C++
В ходе выполнения работы необходимо создать программу, которая определяет и инициализирует двумерный массив целых значений и затем...

Работа с функцией класса - C++
Почему то выскакивает ошибка: &quot;Error 3 error C2228: left of '.Load' must have class/struct/union 14 &quot; #include &lt;iostream&gt; using...

работа с функцией FindFirstFile (API) - C++
Здравствуйте уважаемые. У меня такая проблема - есть буфер (тип char) в нем хранятся пути к файлам, я каждую строку поместил в массив то...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
30
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru