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

Программа в стиле ООП - ошибки - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Как сделать чтобы потом выводило матрицу с максимумом и минимумом, которые я нашел, поменяными местами? http://www.cyberforum.ru/cpp-beginners/thread1311157.html
// #include <iostream> #include<iomanip> #include<cstdlib> using namespace std; int main() { const size_t size(3);
C++ Напишите программу, которая находит сумму ряда напишите программу которая находит сумму 1+1/2+1/3+1/4+.....1/n http://www.cyberforum.ru/cpp-beginners/thread1311153.html
C++ Одномерный массив (вывод наоборот)
Вот моя программа. Она создает массив. Но я не знаю как сделать так, чтобы потом выводился еще и реверсированный массив. int _tmain(int argc, _TCHAR* argv) { const int N = 10; int i; int mas; for(i=1;i<=N;i++) { cout << "mas->"; cin >> mas;
C++ Не читает кириллицу с бинарного файла
У меня не читается кириллица с бинарного файла, то есть читается, но выводится всякая чушь. Что делать? typedef struct {float percent, vklad, nevypl;} client; typedef struct {client x; string type, firm; float cost;} b_firma; ... void showf() { system("cls"); ifstream f1("База данных.bd", ios::binary); f1.read((char*)&B,sizeof(B)); do
C++ Работа с Декой http://www.cyberforum.ru/cpp-beginners/thread1311135.html
Уважаемые форумчане, помогите разобраться, почему не работает функция fill() в моей программе. После выбора создать, или добавить новый элемент, ничего не происходит и совершается выход, хотя, по-идее должен включаться ввод строки. #include "stdafx.h" class Laba { public: void fill(); void addF();
C++ Связной список / дерево Здравствуйте, нужна помощь с программой. Задание прикрепляю. Буду благодарен за любую помощь. Сдавать скоро, а идей по реализации вообще нет. подробнее

Показать сообщение отдельно
takecashman
1 / 1 / 0
Регистрация: 23.05.2013
Сообщений: 33
26.11.2014, 00:20     Программа в стиле ООП - ошибки
Ошибки:
  1. Крякозябры вместо русского
  2. При выводе списка с большим количеством - крах
  3. Не удаляет заявки (Функция del)
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
160
161
162
163
164
165
166
#include <iostream>
#include <conio.h>
#include <clocale>
#include <iomanip>
using namespace std;
//---------------------------------------------------------------------------
class List   {
    public:
    string point;        //
    short reis_n;        //
    char fio[50];          // объявление
    string date;         //
    List *next;
int menu(void);                      //функция вывода Меню
void add(List *first);               //Функция добавления элемента
void cout_one(List *first);          //функция вывода элемента по номеру и дате вылета
void cout_all(List *first);          //функция вывода всего списка
void del(List *first);
                };        //
/*Функция вывода меню:*/
int List::menu (void) {
 
        cout<<setfill('=')<<setw(50)<<"\n";
        cout<<"1 - Добавить заявку"<<endl;
        cout<<"2 - Вывести на экран все заявки"<<endl;
        cout<<"3 - Удалить заявки"<<endl;
        cout<<"4 - Вывод по номеру рейса и дате"<<endl;
        cout<<"0 - Выход"<<"\n"<<setfill('=')<<setw(50)<<"\n"<<endl;
        cout<<setfill(' ');
 
   int key;
   cin>>key;
   cout<<"\n";
   return key; //функция возвращает значение, которое выбрал пользователь
}//конец функции
 
/*функция довабления элемента:*/
void List::add (List *first){
  List *t, *tmp;  //Объявление указателя типа List
 
    for(t=first;t->next!=NULL;t=t->next){};//доходим до последнего элемена списка
 
    tmp=new List; //выделение памяти под новый элемент
 
    /*заполнение нового элемента:*/
    cout<<"Введите пункт назначения:"<<endl;
    cin>>tmp->point;
    cout<<"Введите номер рейса:"<<endl;
    cin>>tmp->reis_n;
    cout<<"Введите ФИО пассажира:"<<endl;
    cin>>tmp->fio;
    cout<<"Введите дату вылета (в формате DD.MM.YY):"<<endl;
    cin>>tmp->date;
    cout<<"\n";
 
    t->next=tmp;  //связываем последний элемент со списком
    delete t, tmp;
}//конец функции
 
/*функция вывода всего списка:*/
void List::cout_all(List *first){
  List *t;
 
    cout<<setfill('*')<<setw(60)<<"\n"<<setfill(' ');
        cout<<"Пункт назначения:"<<setw(8)<<"Рейс:"<<setw(13)
            <<"ФИО:"<<setw(15)<<"Дата вылета:"<<endl;
 
        for(t=first;t->next!=NULL;t=t->next){
          cout<<setw(17)<<t->point<<setw(8)<<t->reis_n<<setw(13)
              <<t->fio<<setw(15)<<t->date<<"\t"<<endl;
        } //конец for
 
        cout<<setw(17)<<t->point<<setw(8)<<t->reis_n<<setw(13)//вывод последнего
            <<t->fio<<setw(15)<<t->date<<"\t"<<endl;          //элемента списка
 
    cout<<setfill('*')<<setw(60)<<"\n"<<setfill(' ')<<"\n";
}//конец функции
 
/*Функция удаления заявок:*/
void List::del(List *first) {
  List *t;
 
        for(t=first;t->next=NULL;t=t->next)
            {
            delete t;
            } //удаление всех элементов списка
}//конец функции
 
/*Функция вывода по номеру рейса и дате вылета:*/
void List::cout_one(List *first){
  List *t;
  int i=0;
    t = new List;
     /*Ввод пользователем номера рейса и даты вылета:*/
     int num;
     string d;
     cout<<"Введите номер рейса:"<<"\n";
     cin>>num;
     cout<<"Введите дату вылета (в формате DD.MM.YY):"<<"\n";
     cin>>d;
     cout<<endl;
 
      for (t=first;(t->next)!=NULL;t=t->next) //цикл просмотра элементов
        {
         if ((t->reis_n==num)&&(t->date==d)) //условие поиска элемента
           {
            /*в случае совпадения выводится элемент:*/
            cout<<"Заявка найдена:"<<"\n";
            cout<<"Пункт назначения:"<<setw(8)<<"Рейс:"<<setw(13)
                <<"ФИО:"<<setw(15)<<"Дата вылета:"<<endl;
            cout<<setw(17)<<t->point<<setw(8)<<t->reis_n<<setw(13)
                <<t->fio<<setw(15)<<t->date<<"\t"<<"\n"<<endl;
            i++; //счетчик количества найденных заявок
           } //конец if
        } //конец for
        /*если условиям поиска удовлетворяет последняя по списку заявка:*/
        if ((t->reis_n==num)&&(t->date==d)) //условие поиска элемента
           {
            cout<<"Заявка найдена:"<<"\n";
            cout<<"Пункт назначения:"<<setw(8)<<"Рейс:"<<setw(13)
                <<"ФИО:"<<setw(15)<<"Дата вылета:"<<endl;
            cout<<setw(17)<<t->point<<setw(8)<<t->reis_n<<setw(13)
                <<t->fio<<setw(15)<<t->date<<"\t"<<"\n"<<endl;
            i++;
            } //конец if
 
      if (i==0) cout<<"Ничего не найдено!"<<"\n"<<endl; //если ничего не найдено
}//конец функции
 
int main()
{
    List ob, *first;
    setlocale(LC_ALL,"Rus");
    first=new List;   //создание первого элемента
 
     /*заполнение первого элемента:*/
     cout<<"Введите пункт назначения:"<<endl;
     cin>>first->point;
     cout<<"Введите номер рейса:"<<endl;
     cin>>first->reis_n;
     cout<<"Введите ФИО пассажира:"<<endl;
     cin>>first->fio;
     cout<<"Введите дату вылета (в формате DD.MM.YY):"<<endl;
     cin>>first->date;
     cout<<"\n";
     first->next=NULL;
    delete first;
   short key;
 
   /*меню пользователя*/
   while((key=ob.menu())!=0)
     {
     switch(key)
        {
        case 1: ob.add(first); break;
        case 2: ob.cout_all(first); break;
        case 3: ob.del(first); break;
        case 4: ob.cout_one(first); break;
        case 5: break;
        default: cout<<"Введите от 1 до 5"<<endl;
        }  //конец switch
     }  //конец while
 
   return 0;
} /*конец main*/
//---------------------------------------------------------------------------
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 06:09. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru