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

массив структур с полями - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Из массива точек найти наибольшее количество лежащих на одной прямой http://www.cyberforum.ru/cpp-beginners/thread772803.html
Из массива точек найти наибольшее количество лежащих на одной прямой Входные данные: Количество точек N N пар - координаты точек. Выходные данные: Ответ на задачу
C++ Заполнение матрицы по спирали с использованием case - break Нужно заполнить матрицу по спирали при помощи case - break. Вот код : #include<iostream> #include<Windows.h> #include "stdlib.h" using namespace std; void main() { SetConsoleOutputCP(1251); const int N=5, M=5; http://www.cyberforum.ru/cpp-beginners/thread772770.html
C++ c++ среднее значение с запятой
Здравствуйте. Кто нить подскажите, как в txt файле сохранить среднее значение с запятой. А то сохраняет только до запятой получается.fprintf(frz,"srednee:%d\n",W);
Кросплатформенные сокеты из коробки C++
Наскольо я понял, в стандартной библиотеке си под линукс есть сокеты(сокеты беркли), но есть ли они под виндой(все время вижу работу через winapi)? Заранее благодарен.
C++ Задача по ООП (создать класс Alfa) http://www.cyberforum.ru/cpp-beginners/thread772740.html
Ребята, помогите, пожалуйста, с задачей. Второй день долблюсь и не понимаю, что не так. Условие: создать класс Alfa таким образом, чтобы при создании первого и уничтожении последнего объекта этого типа на экран выводились соответствующие сообщения. Указание: использовать статические компоненты класса. Вот мой код, объясните, как исправить.#include "stdafx.h" #include <iostream> #include...
C++ Операции над указателями int var = 123; int *p = &var; (*p)++ и ++*p это одно и тоже. В первом случае приоритет задал скобками. 1)Тогда почему *p++ и *p=*p+1 это не одно и тоже? Почему в первом случае мы сдвигаем адрес памяти, а во втором значение переменной? 2). Почему когда я пишу *p++ у меня выводится именно адрес памяти? По сути же ведь сначала тут идёт разыменование, т.е. получаем число 123 и увеличиваем его... подробнее

Показать сообщение отдельно
Sergey_B
163 / 163 / 14
Регистрация: 08.01.2013
Сообщений: 335
27.01.2013, 18:37     массив структур с полями
Пользуйтесь
Кликните здесь для просмотра всего текста
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
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
#include <iostream>
#include <conio.h>
#include <windows.h>
using namespace std;
 
 struct Student
    {                   
        char name[30], group[10];
        int marks[4];
        double MidMark;
    };
    
    FILE *fp;
    //заполнение списка студентов
    Student InputList(Student *stGroup, int N)
    {
            for (int i=0; i<N; i++)
            {
            cout<<"\nВведите фамилию "<<i+1<<"-го студента: ";
               cin>>stGroup[i].name;
            cout<<"\nВведите номер группы: ";
               cin>>stGroup[i].group;
            cout<<"\nВведите 4 oценки студента: "<<stGroup[i].name<<endl;
            stGroup[i].MidMark=0;
               for (int j=0; j<4; j++)
                {
                     cin>>stGroup[i].marks[j];
                     stGroup[i].MidMark+=stGroup[i].marks[j];
                }
                stGroup[i].MidMark=stGroup[i].MidMark/4;
            }
            return *stGroup;
            
    }
    
    //просмотр списка студентов
    void ShowList(Student *stGroup, int N)
    {
         for (int i=0; i<N; i++)
         {
             cout<<"\nФИО: "<<stGroup[i].name;
             cout<<"\nГруппа: "<<stGroup[i].group;
             cout<<"\nОценки: ";
             for (int j=0;j<4;j++)
             {
                 cout<<stGroup[i].marks[j]<<" ";
             }
             cout<<"\nСредний балл: "<<stGroup[i].MidMark;
         }
    }
    
  //список успевающих  
  void ListOfAchievers(Student *stGroup, int N)
  {
    fp=fopen("Список успевающих.txt","w+");
    if (fp==NULL) 
    {
       cout<<"Ошибка создания файла!";
    }
    else
    {
        for (int i=0; i<N; i++)
        {
            
            if (stGroup[i].MidMark>=4)
            {
               fprintf(fp, "Студент:%s, группа: %s, средний балл: %lf\n", stGroup[i].name, stGroup[i].group, stGroup[i].MidMark);
               cout<<"\nOK\n";
            }
        }    
    }
  }
  
  //список не успевающих  
  void ListIsNotAchievers(Student *stGroup, int N)
  {
    fp=fopen("Список не успевающих.txt","w+");
    if (fp==NULL) 
    {
       cout<<"Ошибка создания файла!";
    }
    else
    {
        for (int i=0; i<N; i++)
        {
            if (stGroup[i].MidMark<4)
            {
               fprintf(fp, "Студент:%s, группа: %s, средний балл: %lf\n", stGroup[i].name, stGroup[i].group, stGroup[i].MidMark);
               cout<<"\nOK\n";
            }
        }    
    }
  }
  //cортировка массива структур
  Student SortBy(Student *stGroup, int N, int a) //a - выбор варианта сортировки 
  {
            for (int i=0; i<N; i++)
              {
                  for (int j=i+1; j<N; j++)
                  {
                     //сортировка по номеру группы
                     if( strcmp(stGroup[i].group, stGroup[j].group)>0 && a==1) 
                     {
                          Student buf =  stGroup[i];
                          stGroup[i] = stGroup[j];
                          stGroup[j] =buf;                                
                     }
                     //cортировка по среднему баллу
                     else if (stGroup[i].MidMark<stGroup[j].MidMark && a==2) 
                     {
                          Student buf =  stGroup[i];
                          stGroup[i] = stGroup[j];
                          stGroup[j] =buf;                                
                     }
                     //сортировка по фамилии
                     else if( strcmp(stGroup[i].name, stGroup[j].name)>0 && a==3)
                     {
                          Student buf =  stGroup[i];
                          stGroup[i] = stGroup[j];
                          stGroup[j] =buf;       
                     }
                  }
              }
    return *stGroup;
      
  }         
                 
      
  
  //вывод меню
 void Menu()
 {
     cout<<"\nВыберите действие:\n";
     cout<<"1 - Заполнение списка студентов\n";
     cout<<"2 - Вывод списка студентов\n";
     cout<<"3 - Вывод списка успевающих студентов в файл\n";
     cout<<"4 - Вывод списка неуспевающих студентов в файл\n";
     cout<<"5 - Сортировка по номеру группы\n";
     cout<<"6 - Сортировка по среднему баллу\n";
     cout<<"7 - Сортировка по фамилии\n";
     cout<<"0 - Выход\n";
 }
 
    
int main ( )
{
     SetConsoleCP(1251);  
     SetConsoleOutputCP (1251);
      
     Student InputList(Student *stGroup, int N);
     void ShowList(Student *stGroup, int N);
     void ListOfAchievers(Student *stGroup, int N);
     void ListIsNotAchievers(Student *stGroup, int N);
     Student SortBy(Student *stGroup, int N, int a);
     void Menu();
     int n=0; //кол-во студентов (элементов в массиве)
     while (n<=0)
     {
           cout<<"Введите количество студентов: ";
           cin>>n;
           
     }
    
     Student *stGrp = new Student[n];
     char key; //принимает выбор пользователя
              
     while(true) {
              Menu();
              cin>>key;
              switch(key){
              case '1': *stGrp=InputList(stGrp, n);
                        break;
              case '2': ShowList(stGrp, n);
                        break;
              case '3': ListOfAchievers(stGrp, n);
                        break;
              case '4': ListIsNotAchievers(stGrp, n);
                        break;
              case '5': SortBy(stGrp, n, 1);
                        cout<<"Сортировка по номеру группы выполнена успешно..."; 
                        break;
              case '6': SortBy(stGrp, n, 2);
                        cout<<"Сортировка по среднему баллу выполнена успешно...";  
                        break;
              case '7': SortBy(stGrp, n, 3);
                        cout<<"Сортировка по фамилии выполнена успешно...";  
                        break;
              case '0': return 0;    
              default:    
                        cout<<"\nПовторите выбор:\n";
                        cout<<"Выберите действие:\n";
                        break; 
              
                     }
              }      
               
      
     
              
    
  
  getch();
  delete []stGrp;
  return 0;  
}

Можете добавить еще какие - нибудь свои проверки. Исходя из того, что в примере номер группы char, я предположил что номер группы начинается с букв, поэтому сортировка по номеру группы сделана в алфавитном порядке.

Добавлено через 8 минут
fclose(fp) - забыл, ну сами тогда допишите в функции вывода информации в файл
 
Текущее время: 01:27. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru