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

Структура с именем STUDENT (эпизод 1001) - C++

Восстановить пароль Регистрация
 
Lek
1 / 1 / 0
Регистрация: 16.08.2010
Сообщений: 48
09.01.2012, 01:47     Структура с именем STUDENT (эпизод 1001) #1
Доброй ночи всем.
Не могу никак написать структуру...
1. Описать структуру с именем STUDENT, содержащую следующие поля:
■ фамилия и инициалы;
■ номер группы;
■ успеваемость (массив из пяти элементов).
2. Написать программу, выполняющую следующие действия:
■ ввод с клавиатуры данных в массив, состоящий из десяти структур типа STUDENT; записи должны быть упорядочены по возрастанию среднего балла;
■ вывод на дисплей фамилий и номеров групп для всех студентов, имеющих оценки 4 и 5;
■ если таких студентов нет, вывести соответствующее сообщение.
нашел похожую тему но там не дописана она.
структура STUDENT

 Комментарий модератора 
Lek, Правила
3.3. Запрещено создавать темы с бессмысленными названиями вроде "Помогите!", "Вопрос" и т.п.
Изначальное название темы: "Структура".
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.01.2012, 01:47     Структура с именем STUDENT (эпизод 1001)
Посмотрите здесь:

Описать структуру с именем STUDENT C++
Описать структуру с именем Student C++
Описать структуру с именем STUDENT C++
Описать структуру с именем STUDENT C++
C++ Описать структуру с именем STUDENT
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Gepar
 Аватар для Gepar
1173 / 529 / 20
Регистрация: 01.07.2009
Сообщений: 3,511
09.01.2012, 02:25     Структура с именем STUDENT (эпизод 1001) #2
Lek, ваши наработки?
Вот это

Цитата Сообщение от Lek Посмотреть сообщение
1. Описать структуру с именем STUDENT, содержащую следующие поля:
■ фамилия и инициалы;
■ номер группы;
■ успеваемость (массив из пяти элементов).
Сможет любой смотря на готовый пример, даже мой рыжий кот если ему пример хороший показать.
Lek
1 / 1 / 0
Регистрация: 16.08.2010
Сообщений: 48
09.01.2012, 02:35  [ТС]     Структура с именем STUDENT (эпизод 1001) #3
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
#include <iostream.h>;
#include <stdio.h>;
#include <string.h>;
 
struct STUDENT{
char familiya[15];
char gr[15];
int ysp;
 
} zapis[4]; 
 
void main()
{ 
for (int i=1;i<5;i++)
{
cout<<"Vvod dannix o cheloveke, najmite enter \n "; 
cin>>i;
cout<<"Vvedite familiya \n";
cin >> zapis[i].familiya;
cout<<"Vvedite № gryppbI \n"<<;
cin >> zapis[i].gr;
printf("Vvedite yspevaemostb \n");
cin >> zapis[i].ysp;
 
 
}
char fam[15];
 
int i,j,m,min;
for (i=1;i<5;i++)
{
min=i;
for(j=i+1;j<n;j++) 
if(mas[j].ysp[i]<mas[min].ysp[i]) min=j;
temp=mas[i];
mas[i]=mas[min];
mas[min]=temp;
}
else
{
cout << "Takix studentov net " << endl;
}
}
вот я уже даже переделать чтобы было без printf. А дальше не пойму никак, се лабы сделал структуры никак не пойму.
CJS
49 / 49 / 4
Регистрация: 17.07.2011
Сообщений: 379
09.01.2012, 03:32     Структура с именем STUDENT (эпизод 1001) #4
Вот так структура объявляется , это то, что сразу бросилось в глаза.

C
1
2
3
4
5
6
7
8
struct STUDENT
{
char familiya[15];
char gr[15];
int ysp;
 
};
struct STUDENT  zapis[4];
Gepar
 Аватар для Gepar
1173 / 529 / 20
Регистрация: 01.07.2009
Сообщений: 3,511
09.01.2012, 14:34     Структура с именем STUDENT (эпизод 1001) #5
CJS, с объявлением структуры в коде приведённом Lek и так всё в порядке.
Цитата Сообщение от Lek Посмотреть сообщение
■ ввод с клавиатуры данных в массив, состоящий из десяти структур типа STUDENT; записи должны быть упорядочены по возрастанию среднего балла;
Это у вас уже есть.

Цитата Сообщение от Lek Посмотреть сообщение
■ вывод на дисплей фамилий и номеров групп для всех студентов, имеющих оценки 4 и 5;
■ если таких студентов нет, вывести соответствующее сообщение.
Ну вот вам код, дорабатывайте его
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
#include <iostream>
#include <iomanip>
using namespace std;
 
struct STUDENT{
    char familiya[15];
    char gr[15];
    int ysp;
} zapis[4];
 
bool operator<(const STUDENT &left,const STUDENT &right)
{
    return (left.ysp<right.ysp);
}
 
void printAll(STUDENT *toPrint,int size,int max=0)
{
    bool flag=true;
    for(int i=0;i<size;i++)
    {
        if(toPrint[i].ysp>=max)
         cout<<setw(16)<<toPrint[i].familiya
         <<setw(16)<<toPrint[i].gr
         <<setw(3)<<toPrint[i].ysp<<endl,flag=0;
    }
    if(flag)
     cout<<"!!!!!!!";//студентов для распечатки по заданому критерию нет
}
 
int main ()
{
    zapis[0].ysp=3;
    zapis[1].ysp=5;
    zapis[3].ysp=4;
    sort(zapis,zapis+4);//сортируем
    printAll(zapis,4);//выводим всех
    cout<<endl;
    printAll(zapis,4,4);//только тех у кого 4 и выше
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.03.2012, 19:59     Структура с именем STUDENT (эпизод 1001)
Еще ссылки по теме:

C++ Описать структуру с именем STUDENT
C++ Описать структуру с именем STUDENT
Структура с именем STUDENT C++

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

Или воспользуйтесь поиском по форуму:
Infinity3000
 Аватар для Infinity3000
1057 / 576 / 24
Регистрация: 03.12.2009
Сообщений: 1,255
06.03.2012, 19:59     Структура с именем STUDENT (эпизод 1001) #7
Все условия вашего задания соблюдены, даже больше! структура заполняется из файла!
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
#include "iostream"
#include "fstream"
 
using namespace std;
 
struct student 
{
    char name[20];//фамилия студента
    int group; //номер группы
    int  ses[5]; //оценки
};
 
double sort(student *,int n);    // прототип функции сортировки по среднему балу
double horoshist(student *,int n); // прототип функции вывод студентов у которых 4 и 5
 
int main()
{
    setlocale(LC_CTYPE,"Russian"); //русский шрифт в консоле
    int n, i, j; //обьявляем переменные
    cout << "Введите количество структур типа студент - ";
    cin >> n; //число элементов в массиве структур
    
    student *stud1 = new student [n]; //выделение динамической памяти под массив структур
 
    ifstream instr("inform.txt");   //открытие файла для ввода
    if(!instr) //если файл не найден тогда....
    {
        cout<<"File can not be open\n"; //выводим сообщение
        return 0; //выход из программы
    }                                          
 
    cout << endl << "Фамилия\tГруппа\t\t    Оценки" << endl << endl;
    
    //заполнение массива считыванием из файла
    for(i = 0; i < n; i++)
    { 
        instr >> stud1[i].name >> stud1[i].group;
        cout << stud1[i].name << '\t' << stud1[i].group; 
            for(j = 0; j < 5; j++)
            {
                instr >> stud1[i].ses[j];
                cout << '\t' << stud1[i].ses[j];
            }   
            cout << endl;
    }  
    instr.close(); //закрываем файл
 
    cout << endl << "Mассив STUD1 по возрастанию среднего балла" << endl;
    cout << endl << "Фамилия\tГруппа\t\t     Оценки\t\t     Средний бал" << endl << endl;
    sort(stud1, n); //вызываем функцию сортировки
 
    cout << endl << "Фамилии и номера групп для всех студентов, имеющих оценки 4 и 5" << endl;
    cout << endl << "Фамилия\tГруппа" << endl << endl;
    horoshist(stud1, n); //вызываем функцию для вывода хорошистов
 
    delete [] stud1; //очищаем память
    system("pause >> null"); //ждем пока пользователь нажмет любую клавишу
    return 0; //выход с программы
}
 
 
//сортировку делаеи спомощью "Пузырьковой сортировки"
double sort(student *gr, int n)
{
    double s; //перемееная для подсчета суммы балов каждого студента
    double *avg = new double [n]; //выделяем память под массив хранящщего средние балы каждого студента
    
    //находим средний бал каждого студента
    for(int i = 0; i < n; i++)
    {
        s = 0.;
        for(int j = 0; j < 5; j++)
        {
            s += gr[i].ses[j];
            avg[i] = s / 5;
        }
    }
 
    bool flag = true; //обьявляем булевую переменную и даем есть значение "истина"
        
        while(flag) //пока "истина" делаем
        {
            flag = false;  //устанавливаем переменную в "ложь"
                    
            for(int i = 0; i < n - 1; ++i)
            {
                if(avg[i] > avg[i + 1]) //если элемент массива большн следующий элемент, тогда
                {
                    //меняем массивы в структуре местами
                    student x = gr[i];
                    gr[i] = gr[i + 1];
                    gr[i + 1] = x;
                    
                    //а также меняем местами и элементы в массиве средних оценок 
                    double temp = avg[i];
                    avg[i] = avg[i + 1];
                    avg[i + 1] = temp;
           
                    flag = true; //уснанавлюем в "истина"
                }
            }
        }
 
        //выводим на экран отсортированную структуру
        for(int i = 0; i < n; i++)
    { 
        cout << gr[i].name << '\t' << gr[i].group; 
            for(int j = 0; j < 5; j++)
            {
                cout << '\t' << gr[i].ses[j];
                
            }
            cout << "\t" << avg[i]; //выводим на экран средний бал
            cout << endl;
    }  
    delete [] avg; //освобождаем память
    return 0;
}
 
 
//ищем хорошистов
double horoshist(student *gr, int n)
{
    int x, z = 0; //объявляем переменные
 
    for(int i = 0; i < n; i++)
    {
        x = 0;
        for(int j = 0; j < 5; j++)
        {
            
            if(gr[i].ses[j] == 4 || gr[i].ses[j] == 5)
            {
                x++; //считаем количество 4 и 5 у каждого студента
            }
        }
        if (x == 5) //если еоличество 4 и 5 равен 5 тогда...
        {
            cout << gr[i].name << '\t' << gr[i].group << endl; //выводи этих студентов
            z++;//подсчитываем количеств хорошистов
        }
        
    }
    if (z == 0) //если хорошистов нет, тогда ....
        {
            cout << "Среди студентов нет хорошистов" <<endl; //выводим сообщение об этом
        }
    return 0;
}
Миниатюры
Структура с именем STUDENT (эпизод 1001)  
Вложения
Тип файла: txt inform.txt (460 байт, 37 просмотров)
Yandex
Объявления
06.03.2012, 19:59     Структура с именем STUDENT (эпизод 1001)
Ответ Создать тему

Метки
student, student c++, описать структуру, описать структуру c++, описать структуру student c++, описать структуру student, описать структуру с именем student, структура student, структура student c++, структуры данных, структуры данных c++
Опции темы

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