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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.89
SKS-65
5 / 5 / 1
Регистрация: 18.10.2011
Сообщений: 187
#1

Сортировка массива объектов класса - C++

10.05.2013, 21:07. Просмотров 1174. Ответов 4
Метки нет (Все метки)

Пишу программу в которой есть массив объектов и методы которые его сортируют, но после сортировки ничего не выводится, а просто чистое консольное окно, помогите разобраться
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
TMagnitafon.h
 
#pragma once
#include "string.h"
class TMagnitafon
{
public:
    char pType[30];
    char pFirma[30];
    char pData[30];
    bool CD;
    int kass;
    bool priem;
    double price;
    void Print();
    void SortPriceAndPrint();
    TMagnitafon(){
        strcpy(pType,""); strcpy(pFirma,""); strcpy(pData,""); CD=0; kass=0; priem=0; price=0;
    }
};
 
Magnitafon.cpp
 
#include "StdAfx.h"
#include "TMagnitafon.h"
#include "iostream"
#include "TWork.h"
using namespace std;
 
void TMagnitafon::Print()
{
    cout<<pType<<" "<<pFirma<<" "<<pData<<" "<<CD<<" "<<kass<<" "<<priem<<" "<<price<<"\n";
}
 
TWork.h
 
#pragma once
#include "TMagnitafon.h"
class TWork
{
public:
    TMagnitafon* List;
    int N;
    int n;
public:
    TMagnitafon* CreatMass(char* pType,char* pFirma,char* pData,bool CD,int kass,bool priem,double price);
    TMagnitafon* GetMass(int q);
    void SortAndPrint(TWork* ptr);
    TWork();
    ~TWork(){delete [] List;};
    TMagnitafon* AddList();
};
 
TWork.cpp
 
#include "StdAfx.h"
#include "TWork.h"
#include "iostream"
using namespace std;
 
TMagnitafon* TWork::CreatMass(char* pType,char* pFirma,char* pData,bool CD,int kass,bool priem,double price)
{
    TMagnitafon* mass=AddList();
    strcpy(mass->pType,pType);
    strcpy(mass->pFirma,pFirma);
    strcpy(mass->pData,pData);
    mass->CD=CD;
    mass->kass=kass;
    mass->priem=priem;
    mass->price=price;
    return mass;
 
}
 
TWork::TWork()
{
    n=0;
    N=100;
    List=new TMagnitafon[10];
}
 
TMagnitafon* TWork::AddList()
{
    if (n<N)
    {
        n++;
        return &(List[n-1]);
    }
    else
        return NULL;
}
 
TMagnitafon* TWork::GetMass(int q)
{
    if (q<0 || q>=N) return NULL;
    return &(List[q]);
}
 
void TWork::SortAndPrint(TWork* ptr) //вот сама сортировка
{
 
    TMagnitafon* x;
    bool t;
    do
    {
        t=true;
        for (int i=0;i<n-1;i++)
            if (strcmp(ptr->GetMass(i)->pFirma,ptr->GetMass(i+1)->pFirma)==1)
            {
                strcpy(x->pType,ptr->GetMass(i+1)->pType);
                strcpy(x->pFirma,ptr->GetMass(i+1)->pFirma);
                strcpy(x->pData,ptr->GetMass(i+1)->pData);
                x->CD=ptr->GetMass(i+1)->CD;
                x->kass=ptr->GetMass(i+1)->kass;
                x->priem=ptr->GetMass(i+1)->priem;
                x->price=ptr->GetMass(i+1)->price;
 
                strcpy(ptr->GetMass(i+1)->pType,ptr->GetMass(i)->pType);
                strcpy(ptr->GetMass(i+1)->pFirma,ptr->GetMass(i)->pFirma);
                strcpy(ptr->GetMass(i+1)->pData,ptr->GetMass(i)->pData);
                ptr->GetMass(i+1)->CD=ptr->GetMass(i)->CD;
                ptr->GetMass(i+1)->kass=ptr->GetMass(i)->kass;
                ptr->GetMass(i+1)->priem=ptr->GetMass(i)->priem;
                ptr->GetMass(i+1)->price=ptr->GetMass(i)->price;
 
                strcpy(ptr->GetMass(i)->pType,x->pType);
                strcpy(ptr->GetMass(i)->pFirma,x->pFirma);
                strcpy(ptr->GetMass(i)->pData,x->pData);
                ptr->GetMass(i)->CD=x->CD;
                ptr->GetMass(i)->kass=x->kass;
                ptr->GetMass(i)->priem=x->priem;
                ptr->GetMass(i)->price=x->price;
 
                t=false;
            }
    }while(!t);
    for (int i=0;i<n;i++)
        cout<<ptr->GetMass(i)<<" "<<ptr->GetMass(i)<<" "<<ptr->GetMass(i)<<" "<<ptr->GetMass(i)<<" "<<ptr->GetMass(i)<<" "<<ptr->GetMass(i)<<" "<<ptr->GetMass(i)<<"\n";
 
}
 
MAG.cpp
 
#include "stdafx.h"
#include "TMagnitafon.h"
#include "conio.h"
#include "iostream"
#include "TWork.h"
using namespace std;
void main()
{
    TWork ptr;
    TWork* ptr2;
    TMagnitafon* x=ptr.CreatMass("sdf","fdgf","hj",0,32,1,23);
    x=ptr.CreatMass("erty","hfdg","ghbn",1,234,1,43.6);
    ptr2->SortAndPrint(ptr2);
    getch();
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.05.2013, 21:07     Сортировка массива объектов класса
Посмотрите здесь:

Создание Массива Объектов класса C++
Сортировка массива объектов, созданных с помощью класса C++
C++ Узнать размер (количество) массива объектов класса
C++ Создание массива объектов класса
C++ Сортировка массива с объектами класса
Не работает сортировка объектов класса C++
Изменение размера динамического массива объектов класса C++
Метод для массива объектов класса C++
C++ Создание массива объектов класса
Сортировка элементов массива объектов в классе C++
Массив объектов класса, отладка, доступ к полям элемента массива C++
C++ Создание массива объектов класса через список инициализации в конструкторе композита

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
anmartex
...
1701 / 1194 / 494
Регистрация: 12.02.2013
Сообщений: 1,978
11.05.2013, 10:16     Сортировка массива объектов класса #2
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
#include <iostream>
#include <cstring>
 
using namespace std;
 
class TMagnitafon
{
   public:
      char pType[30];
      char pFirma[30];
      char pData[30];
      bool CD;
      int kass;
      bool priem;
      double price;
      void Print();
      TMagnitafon()
      {
         *pType = 0;
         *pFirma = 0;
         *pData = 0;
         CD = 0;
         kass = 0;
         priem = 0;
         price = 0;
      }
};
 
void TMagnitafon::Print()
{
   cout << pType << " " << pFirma << " "
        << pData << " " << CD << " "
        << kass << " " << priem << " "
        << price << endl;
}
 
class TWork
{
   public:
      TMagnitafon* List;
      int N;
      int n;
 
   public:
      TWork();
      ~TWork()
      {
         delete [] List;
      };
      TMagnitafon* CreatMass(const char* pType, const char* pFirma,
                             const char* pData, bool CD, int kass,
                             bool priem, double price);
      TMagnitafon* GetMass(int q);
      static void SortAndPrint(TWork& ptr);
      TMagnitafon* AddList();
};
 
TMagnitafon* TWork::CreatMass(const char* pType, const char* pFirma,
                              const char* pData, bool CD, int kass,
                              bool priem, double price)
{
   TMagnitafon* mass = AddList();
   strcpy(mass->pType, pType);
   strcpy(mass->pFirma, pFirma);
   strcpy(mass->pData, pData);
   mass->CD = CD;
   mass->kass = kass;
   mass->priem = priem;
   mass->price = price;
   return mass;
 
}
 
TWork::TWork()
{
   n = 0;
   N = 100;
   List = new TMagnitafon[N];
}
 
TMagnitafon* TWork::AddList()
{
   if (n < N)
   {
      n++;
      return &(List[n - 1]);
   }
   else
   {
      return NULL;
   }
}
 
TMagnitafon* TWork::GetMass(int q)
{
   if (q < 0 || q >= N)
   {
      return NULL;
   }
   return &(List[q]);
}
 
void TWork::SortAndPrint(TWork& ptr) //вот сама сортировка
{
   TMagnitafon x;
   bool t;
   do
   {
      t = true;
      for (int i = 0; i < ptr.n - 1; i++)
         if (strcmp(ptr.GetMass(i)->pFirma, ptr.GetMass(i + 1)->pFirma) > 0)
         {
            strcpy(x.pType, ptr.GetMass(i + 1)->pType);
            strcpy(x.pFirma, ptr.GetMass(i + 1)->pFirma);
            strcpy(x.pData, ptr.GetMass(i + 1)->pData);
            x.CD = ptr.GetMass(i + 1)->CD;
            x.kass = ptr.GetMass(i + 1)->kass;
            x.priem = ptr.GetMass(i + 1)->priem;
            x.price = ptr.GetMass(i + 1)->price;
 
            strcpy(ptr.GetMass(i + 1)->pType, ptr.GetMass(i)->pType);
            strcpy(ptr.GetMass(i + 1)->pFirma, ptr.GetMass(i)->pFirma);
            strcpy(ptr.GetMass(i + 1)->pData, ptr.GetMass(i)->pData);
            ptr.GetMass(i + 1)->CD = ptr.GetMass(i)->CD;
            ptr.GetMass(i + 1)->kass = ptr.GetMass(i)->kass;
            ptr.GetMass(i + 1)->priem = ptr.GetMass(i)->priem;
            ptr.GetMass(i + 1)->price = ptr.GetMass(i)->price;
 
            strcpy(ptr.GetMass(i)->pType, x.pType);
            strcpy(ptr.GetMass(i)->pFirma, x.pFirma);
            strcpy(ptr.GetMass(i)->pData, x.pData);
            ptr.GetMass(i)->CD = x.CD;
            ptr.GetMass(i)->kass = x.kass;
            ptr.GetMass(i)->priem = x.priem;
            ptr.GetMass(i)->price = x.price;
 
            t = false;
         }
   }
   while (!t);
   for (int i = 0; i < ptr.n; i++)
   {
      ptr.GetMass(i)->Print();
   }
 
}
 
int main()
{
   TWork ptr;
   ptr.CreatMass("aaa", "aaa", "aaa", 1, 1111, 1, 43.6);
   ptr.CreatMass("zzz", "zzz", "zzz", 2, 2222, 1, 43.6);
   ptr.CreatMass("yyy", "yyy", "yyy", 3, 3333, 1, 43.6);
   ptr.CreatMass("bbb", "bbb", "bbb", 4, 4444, 1, 43.6);
 
   TWork::SortAndPrint(ptr);
 
   return 0;
}
Название: tmp.png
Просмотров: 187

Размер: 6.5 Кб
SKS-65
5 / 5 / 1
Регистрация: 18.10.2011
Сообщений: 187
11.05.2013, 22:06  [ТС]     Сортировка массива объектов класса #3
anmartex, а вот вы здесь объявляете статический метод
C++
1
 static void SortAndPrint(TWork& ptr);
,а ведь статические методы могут работать только со статическими полями,как тут тогда всё работает?
anmartex
...
1701 / 1194 / 494
Регистрация: 12.02.2013
Сообщений: 1,978
12.05.2013, 10:42     Сортировка массива объектов класса #4
Цитата Сообщение от SKS-65 Посмотреть сообщение
а ведь статические методы могут работать только со статическими полями ...
Да, конечно.

Цитата Сообщение от SKS-65 Посмотреть сообщение
... как тут тогда всё работает?
А почему ему не работать? Ведь метод выполняет действия над пришлым объектом и свои поля вообще не использует.

Вообще, данный метод вы таковым сделали, просто в вашем случае приходилось иметь под рукой лишний объект, чтобы выполнить сортировку над другим объектом. Улавливаете абсурдность? Поэтому был выбор, либо ориентировать этот метода на свой объект, либо сделать его статичным и таким образом исключить необходимость наличия второго объекта. Я выбрал второе.
SKS-65
5 / 5 / 1
Регистрация: 18.10.2011
Сообщений: 187
12.05.2013, 12:08  [ТС]     Сортировка массива объектов класса #5
А всё понял, спасибо
Yandex
Объявления
12.05.2013, 12:08     Сортировка массива объектов класса
Ответ Создать тему
Опции темы

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