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

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

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

не работает qsort - C++

11.03.2012, 17:18. Просмотров 1637. Ответов 27
Метки нет (Все метки)

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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#include <iostream>
#include  <math.h>
#include <iomanip>
#include <string.h>
using namespace std;
 
struct MARSH
{
    char nac_punkt[100];
    char konec_punkt[100];
    int   nomer;
    int   dlina;
}*p1[50];
int comp(const void* a, const void* b)
{
    const  MARSH* k = (const  MARSH*)a;
    const  MARSH* m = (const  MARSH*)b;
    int s = ((k ->dlina) - (m ->dlina));
       
    return s;
}
void  main(void)
{
    FILE *f1;
    setlocale(LC_ALL,"Russian");
    if((f1=fopen("2.dat", "rb+"))==NULL) {
        printf("Ошибка при открытии файла.\n");
        exit(1);
    }
 
 
    for(int i=0;i<5;i++)
    {
        MARSH *pmarh=new MARSH[i+1];
 
        if (pmarh != NULL) cout << "Память успешно выделена" << endl; 
        else cout << "Ошибка выделения памяти" << endl; 
        fread(&pmarh[i],sizeof(MARSH),1,f1);
        p1[i]=&pmarh[i];
        cout<<i+1<<"-aя запись"<<endl;
        cout<<"начальный пункт  "<<pmarh[i].nac_punkt<<endl;
        cout<<"название конечного пункта  "<<pmarh[i].konec_punkt<<endl;
        cout<<"длина  "<<pmarh[i].dlina<<endl;
        cout<<"номер   "<<pmarh[i].nomer<<endl; 
    }
    cout<<"Сортировка"<<endl;
    cout<<endl;
    cout<<endl;
    cout<<endl;
    cout<<endl;
    cout<<endl;
    cout<<endl;
    cout<<endl;
    qsort(p1, 5, sizeof(p1[0]), comp);
    for(int i=0;i<5;i++)
    {      
        cout<<i+1<<"-aя запись"<<endl;
        cout<<"начальный пункт  "<<p1[i]->nac_punkt<<endl;
        cout<<"название конечного пункта  "<<p1[i]->konec_punkt<<endl;
        cout<<"длина  "<<p1[i]->dlina<<endl;
        cout<<"номер   "<<p1[i]->nomer<<endl    
    }
    fclose(f1);
    system("PAUSE");
}
не работает qsort нужным образом тоесть не сортирует

Добавлено через 14 минут
посмотрите пожалуйста код почему qsort не хочет сортировать
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.03.2012, 17:18
Здравствуйте! Я подобрал для вас темы с ответами на вопрос не работает qsort (C++):

не работает qsort - C++
Возникла проблема: в MSVS 2010 данный код выполняется неправильно, массив не сортируется,этот же код, скомпилированный в gcc работает как...

Не работает функция qsort - C++
Вот код #include &lt;iostream&gt; #include &lt;fstream&gt; #include &lt;Windows.h&gt; #include &lt;string&gt; #include &lt;cmath&gt; using namespace...

qsort объясните как работает - C++
Объясните в подробностях как работает данная функция сортировки и как её использовать. К примеру если надо просортировать данный масив: ...

qsort - C++
Вот код программы. Посмотрите вопрос в комментарии. #include &lt;iostream&gt; #include &lt;stdlib.h&gt; using namespace std; int main() ...

qsort - C++
Вот код: #include &lt;cstdio&gt; #include &lt;algorithm&gt; int compare(const void *s1, const void *s2) { return strcmp((char *)s1, (char...

qsort - C++
Ребят,расскажи подробно и простенько про qsort;Видел тему,но ничего не понял.Я новичек еще можно сказать пока в С++. у меня просто...

27
gooseim
Эксперт С++
508 / 412 / 37
Регистрация: 23.09.2010
Сообщений: 1,159
11.03.2012, 18:49 #16
Xind, выносить как раз не надо, иначе в p1 будут все одинаковые элементы = последнему считанному.
1
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
11.03.2012, 18:53  [ТС] #17
спасибо учту

Добавлено через 1 минуту
MARSH *pmarh=new MARSH если так то повреждениче кучи ошибка
0
gooseim
Эксперт С++
508 / 412 / 37
Регистрация: 23.09.2010
Сообщений: 1,159
11.03.2012, 18:55 #18
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
for(int i=0;i<5;i++)
    {
        MARSH *pmarh=new MARCH;
 
        if (pmarh != NULL) cout << "Память успешно выделена" << endl; 
        else cout << "Ошибка выделения памяти" << endl; 
        fread(pmarh,sizeof(MARSH),1,f1);
        p1[i]=pmarh;
        cout<<i+1<<"-aя запись"<<endl;
        cout<<"начальный пункт  "<<pmarh->nac_punkt<<endl;
        cout<<"название конечного пункта  "<<pmarh->konec_punkt<<endl;
        cout<<"длина  "<<pmarh->dlina<<endl;
        cout<<"номер   "<<pmarh->nomer<<endl; 
    }
0
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
11.03.2012, 19:00  [ТС] #19
а вот хочу освободить память в конце так оно не возможно только если в цикле освобождать а я хочу после цикла освободитть
0
gooseim
Эксперт С++
508 / 412 / 37
Регистрация: 23.09.2010
Сообщений: 1,159
11.03.2012, 19:21 #20
В самом конце.
C++
1
2
3
4
for(int i=0;i<5;i++)
{
  delete p1[i];
}
0
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
11.03.2012, 21:30  [ТС] #21
я выделял pmarh как ее завершить
0
gooseim
Эксперт С++
508 / 412 / 37
Регистрация: 23.09.2010
Сообщений: 1,159
11.03.2012, 22:55 #22
sergeu90, pmath = p1
Можно удалять хоть оттуда хоть оттуда
0
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
12.03.2012, 01:03  [ТС] #23
не могу удалить вне цикла пишит не известный индетефикатор
0
gooseim
Эксперт С++
508 / 412 / 37
Регистрация: 23.09.2010
Сообщений: 1,159
12.03.2012, 01:04 #24
C++
1
2
3
4
for(int i=0;i<5;i++)
{
  delete p1[i];
}
0
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
12.03.2012, 01:26  [ТС] #25
вы освобождаете p1 а надо не то освобождать
0
gooseim
Эксперт С++
508 / 412 / 37
Регистрация: 23.09.2010
Сообщений: 1,159
12.03.2012, 01:27 #26
sergeu90, я уже объяснял выше.
C++
1
2
3
int *n = new int(10);
int *m = n;
delete m;
Удалится n, т.к. m = n.
1
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
12.03.2012, 01:48  [ТС] #27
все равно не могу присвоить в не цикла pmarh = p1; пишит не определенный pmarh
0
gooseim
Эксперт С++
508 / 412 / 37
Регистрация: 23.09.2010
Сообщений: 1,159
12.03.2012, 02:08 #28
Вы это и так делаете внутри цикла.
C++
1
p1[i]=pmarh;
От вас только требуется удалить каждый элемент из p1, как я писал.
0
12.03.2012, 02:08
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.03.2012, 02:08
Привет! Вот еще темы с ответами:

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

qsort - C++
читал, что с помощю QSORT можно упорядочить масив, но не пишет как. помогите!!

Вопрос по ()qsort - C++
есть массив, который разбивает предложение на слова. надо отсортировать все слова в порядке возрастание длинны. язык С. заранее...

qsort vs sort - C++
Собственно вопрос что лутше, в каких ситуациях, и почему , спасибо


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

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

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