Форум программистов, компьютерный форум CyberForum.ru

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

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.92
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
20.12.2011, 17:44     работа с функцией qsort #1
вот есть код который отделает слова и записывает в массив и надо их отсортировать по возрастанию длины как использовать 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");
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.12.2011, 17:44     работа с функцией qsort
Посмотрите здесь:

C++ Работа с функцией
задание с функцией qsort(). язык C C++
Работа с функцией класса C++
C++ Работа с функцией
Возникли трудности с функцией быстрой сортировки qsort C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
20.12.2011, 22:00  [ТС]     работа с функцией qsort #21
оно выводит не отсортированно по длине
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
OstapBender
 Аватар для OstapBender
581 / 519 / 35
Регистрация: 22.03.2011
Сообщений: 1,585
20.12.2011, 22:03     работа с функцией qsort #22
надо изменить 1 строчку
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
20.12.2011, 22:03  [ТС]     работа с функцией qsort #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");
}
вот код что тут надо изменить не понимаю
OstapBender
 Аватар для OstapBender
581 / 519 / 35
Регистрация: 22.03.2011
Сообщений: 1,585
20.12.2011, 22:07     работа с функцией qsort #24
ну будь добр подумай немножко
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
20.12.2011, 22:08  [ТС]     работа с функцией qsort #25
да уже день ломаю голову не могу понять про какие три буквы имете ввиду
OstapBender
 Аватар для OstapBender
581 / 519 / 35
Регистрация: 22.03.2011
Сообщений: 1,585
20.12.2011, 22:08     работа с функцией qsort #26
ну и всё таки как было сказано измени уж 4 на sizeof(mas[0])

про 3 буквы я уже стер.
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
20.12.2011, 22:09  [ТС]     работа с функцией qsort #27
все равно не выводит отсортировано просто вывоводит слова
go
Эксперт C++
3582 / 1362 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
20.12.2011, 22:13     работа с функцией qsort #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;
}
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
20.12.2011, 22:14  [ТС]     работа с функцией qsort #29
этот код тоже не выводит в порядке возрастания слова
go
Эксперт C++
3582 / 1362 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
20.12.2011, 22:15     работа с функцией qsort #30
sergeu90, http://liveworkspace.org/code/263a3c...b05a122cc4d7c6
OstapBender
 Аватар для OstapBender
581 / 519 / 35
Регистрация: 22.03.2011
Сообщений: 1,585
20.12.2011, 22:16     работа с функцией qsort #31
go, ему нужно по ДЛИНЕ слова выводить, и он не может понять как изменить код
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
20.12.2011, 22:16  [ТС]     работа с функцией qsort #32
должно с самого малой длины слова до самой большой выводить
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
20.12.2011, 22:18     работа с функцией qsort
Еще ссылки по теме:

работа с функцией в С++ C++
Пожскажите с функцией sort() или qsort() C++
C++ Работа функции qsort - объяснить работу функции

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

Или воспользуйтесь поиском по форуму:
go
Эксперт C++
3582 / 1362 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
20.12.2011, 22:18     работа с функцией qsort #33
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 strlen ( *(char **)a) - strlen ( *(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;
}
Yandex
Объявления
20.12.2011, 22:18     работа с функцией qsort
Ответ Создать тему
Опции темы

Текущее время: 23:26. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru