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

С++ класс, ошибка в методах - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Функция http://www.cyberforum.ru/cpp-beginners/thread199460.html
Всем привет. С функциями туговато у меня, что поделать, зато с остальным хорошо)) Необходимо проверить попадание точки в заштрихованную область, заранее спс))
C++ SIGABRT после free malloc не могу почистить string array matches (2 dim) проблема возникает на линии 114 отмеченной как //Cleaning up an array не могу почистить din.alloc.array с помощью free() на дебаге выдает ошибку SIGABRT #ifndef __PROGTEST__ #include <cstdlib> #include <stdio.h> #endif http://www.cyberforum.ru/cpp-beginners/thread199459.html
масимальный и минемальный элемент в матрице C++
Ввести число N – порядок квадратной матрицы. Последовательно по строкам ввести с клавиатуры все элементы матрицы. Вывести матрицу на экран и сообщить, какой элемент является минимальным и его координаты, а какой максимальным и его координаты
C++ Ввести строку
1)Ввести строку S и символ CH. Найти в строке S первую букву CH и удалить следующую за ней часть строки 2)Ввести строку с пробелами и выделить из предложения первое слово (слова разделены пробелом). Вывести также на экран длину строки. Добавлено через 17 часов 19 минут uuupp
C++ Надо написать программы!!! http://www.cyberforum.ru/cpp-beginners/thread199451.html
Привет всем! Помогите написать программы!!! Задание 1. Для компьютера на своем рабочем месте определить: • тип компьютера; • конфигурацию оборудования; • объем оперативной памяти; • наличие и объем расширенной памяти; • наличие дополнительных ПЗУ; • версию операционной системы.
C++ Массив Дан массив (12) Найти и вынести номера нулевых элементов , расположенных между первым максимальным и последним максимальным элементом. подробнее

Показать сообщение отдельно
HenryL
2 / 2 / 0
Регистрация: 14.04.2010
Сообщений: 32
29.11.2010, 16:18     С++ класс, ошибка в методах
Итак, вот пишу прогу
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
#include <stdio.h> 
#include <string> 
#include "stdafx.h" 
#include "fstream" 
#include "conio.h" 
#include "math.h" 
#include "iostream"  
 
using namespace std; 
 
class aeroflot 
{public: 
     
    int i, numb; 
    char type[100]; 
    char dest[100]; 
    void enter(aeroflot *reys) 
    {    int i, kol; 
    kol=2; 
        cout << "Введите данные: " << endl; 
        cout << "" <<endl; 
        for (i=0; i<kol; i++)// цикл для ввода данных о рейсе 
            { 
                for (int o=0; o<kol; o++) 
                    { 
                        { 
                            cout << i+1 <<"-й маршрут." << endl; 
                            cout << "Пункт назначения (не более 10 симв.): "; 
                            cin >> reys[i].dest; 
                            cout << "Номер рейса: "; 
                            cin >> reys[i].numb; 
                            cout << "Тип самолета (не более 10 симв.): "; 
                            cin >> reys[i].type; 
                        } 
                        cout << "" <<endl; 
                        break; 
                    } 
                         
            } 
        for (i = 0; i < 2 ; i++)  
    { 
        cout << reys[i].dest <<"   " << reys[i].numb << "   " << reys[i].type << endl;  
    } 
 
    } 
 
    void sortname(aeroflot *reys, aeroflot *dest, aeroflot *type, aeroflot numb)
{ 
    int j,k; 
 aeroflot p; 
 for(j=0; j<2; j++) 
  { 
   for(k=0; k<2; k++) 
    { 
     if(strcmp(reys[j].dest,reys[k].dest)<0) 
          { 
       p=reys[j]; 
       reys[j]=reys[k]; 
       reys[k]=p; 
      } 
    } 
  } 
 
cout << "Маршруты по нункту назначения: " << endl; 
cout << " " << endl; 
for (i = 0; i < 2 ; i++)  
    { 
        cout << reys[i].dest <<"   " << reys[i].numb << "   " << reys[i].type << endl;  
    } 
 
 
    } 
 
 void search(aeroflot *reys, aeroflot *dest, aeroflot *type, aeroflot numb, int kol) 
 { 
     while (true) 
{  
    char inp [10]; 
    cout << endl << "Ввведите пункт назначения: ";   
    cin >> inp;  
    cout << endl; 
    bool f = false;// флаг (найдено ли хотя бы одно) 
    for (i=0; i<kol; i++) 
    {     
        if (strcmp (reys[i].dest, inp)==0)//сравнение введенной строки с массивом пунктов назначения 
            { 
                cout << "Найдено!" << endl; 
                cout << "Номер рейса: " <<' '<< reys[i].numb<<' '<< "Тип самолета: " <<' '<< reys[i].type << ' '<<endl;  
                f = true;  
            } 
    } 
        if (!f) cout << "Нет такого пункта назначения!";  
 
 } 
 } 
     
}; 
 
int _tmain(aeroflot *dest, aeroflot *type, aeroflot numb, int kol ) 
{ 
    setlocale(0,"Rus"); 
    // 
    aeroflot reys[2]; 
reys[2].enter(reys); 
reys[2].sortname(reys, dest, type, numb); 
reys[2].search(reys, dest, type, numb, kol); 
 
    _getch(); 
}
Структура с тремя полями - тип самолета, номер рейса, пункт назначения на семь записей (тут я сделал на две, чтобы тестировать быстрее, не вводить каждый раз по семь записей).
Во первых, там ошибка есть, с выходом за пределы в reys (ее видно, если убрать метод search() с вечным циклом while, который не дает завершится проге и выдать ошибку). Во вторых, собсно функция search не хочет ничего искать!
Я так думаю, что я как-то коряво передаю данные функциям, отсюда и ошибки. Посмотрите пожалуйста, возможно, исправить мои ошибки очень легко, а я никак не соображу.

Добавлено через 35 минут
не структура, класс

Добавлено через 8 часов 54 минуты
ааа, посмотрите кто-нибудь этот код, я ничего не понимаю!

Добавлено через 33 минуты
Так, слегка разобрался, повыкидывал лишнее из передаваемых параметров. Теперь все работает, но ошибка про выход за пределы массива при завершении проги остался...

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
#include <stdio.h>
#include <string>
#include "stdafx.h"
#include "fstream"
#include "conio.h"
#include "math.h"
#include "iostream" 
 
using namespace std;
 
class aeroflot
{public:
    
    int i, numb;
    char inp [10];
    char type[100];
    char dest[100];
    void enter(aeroflot *reys)
    {   int i, kol;
    kol=2;
        cout << "Введите данные: " << endl;
        cout << "" <<endl;
        for (i=0; i<kol; i++)// цикл для ввода данных о рейсе
            {
                for (int o=0; o<kol; o++)
                    {
                        {
                            cout << i+1 <<"-й маршрут." << endl;
                            cout << "Пункт назначения (не более 10 симв.): ";
                            cin >> reys[i].dest;
                            cout << "Номер рейса: ";
                            cin >> reys[i].numb;
                            cout << "Тип самолета (не более 10 симв.): ";
                            cin >> reys[i].type;
                        }
                        cout << "" <<endl;
                        break;
                    }
                        
            }
        for (i = 0; i < 2 ; i++) 
    {
        cout << reys[i].dest <<"   " << reys[i].numb << "   " << reys[i].type << endl; 
    }
 
    }
 
    void sortname(aeroflot *reys)//struct_data - тип данных структуры,  n - количество элементов структуры
{
    int j,k;
 aeroflot p;
 for(j=0; j<2; j++)
  {
   for(k=0; k<2; k++)
    {
     if(strcmp(reys[j].dest,reys[k].dest)<0)
          {
       p=reys[j];
       reys[j]=reys[k];
       reys[k]=p;
      }
    }
  }
 
cout << "Маршруты по нункту назначения: " << endl;
cout << " " << endl;
for (i = 0; i < 2 ; i++) 
    {
        cout << reys[i].dest <<"   " << reys[i].numb << "   " << reys[i].type << endl; 
    }
    }
    void search(aeroflot *reys)
    {
 while (true)
{ int kol = 2;
 
    cout << endl << "Ввведите пункт назначения: ";  
    cin >> inp; 
    cout << endl;
    bool f = false;// флаг (найдено ли хотя бы одно)
    for ( int i=0; i<kol; i++)
    {   
        if (strcmp (reys[i].dest, inp)==0)//сравнение введенной строки с массивом пунктов назначения
            {
                cout << "Найдено!" << endl;
                cout << "Номер рейса: " <<' '<< reys[i].numb<<' '<< "Тип самолета: " <<' '<< reys[i].type << ' '<<endl; 
                f = true; 
                break;
            }
    }
        if (!f) cout << "Нет такого пункта назначения!"; 
        break;
 
 }
 
 
 
    }
    
};
 
int _tmain()
{
    setlocale(0,"Rus");
    //
    aeroflot reys[2];
reys[2].enter(reys);
reys[2].sortname(reys);
reys[2].search(reys);
 
    _getch();
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 08:02. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru