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

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

Войти
Регистрация
Восстановить пароль
 
Lek
1 / 1 / 0
Регистрация: 16.08.2010
Сообщений: 48
#1

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

09.01.2012, 01:47. Просмотров 1107. Ответов 6

Доброй ночи всем.
Не могу никак написать структуру...
1. Описать структуру с именем STUDENT, содержащую следующие поля:
■ фамилия и инициалы;
■ номер группы;
■ успеваемость (массив из пяти элементов).
2. Написать программу, выполняющую следующие действия:
■ ввод с клавиатуры данных в массив, состоящий из десяти структур типа STUDENT; записи должны быть упорядочены по возрастанию среднего балла;
■ вывод на дисплей фамилий и номеров групп для всех студентов, имеющих оценки 4 и 5;
■ если таких студентов нет, вывести соответствующее сообщение.
нашел похожую тему но там не дописана она.
структура STUDENT

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

Структура с именем STUDENT - C++
Исправьте, пожалуйста, программу(работа со структурами) и объясните, как вы это сделали! Описать структуру с именем STUDENT,...

Описать структуру с именем STUDENT - C++
Описать структуру с именем STUDENT, содержащую следующие поля:  фамилия и инициалы;  номер группы;  успеваемость (массив из пяти...

Описать структуру с именем Student - C++
Описать структуру с именем Student, содержащую следующие поля: имя, группа, успеваемость (массив из 4 элементов). Написать программу,...

Описать структуру с именем Student - C++
Описать структуру с именем STUDENT, содержащую следующие поля: 1) фамилия и инициалы; 2) номер группы; 3) успеваемость (массив из...

Описать структуру с именем STUDENT - C++
помогите,пожалуйста! написала прогу,она не работает(((( #include "stdafx.h" #include <stdio.h> #include<conio.h> ...

Описать структуру с именем STUDENT - C++
Пожалуйста помогите! Описать структуру с именем STUDENT, содержащую следующие поля: • NAME - фамилия и инициалы; • GROUP - номер...

6
Gepar
1177 / 533 / 20
Регистрация: 01.07.2009
Сообщений: 3,517
09.01.2012, 02:25 #2
Lek, ваши наработки?
Вот это

Цитата Сообщение от Lek Посмотреть сообщение
1. Описать структуру с именем STUDENT, содержащую следующие поля:
■ фамилия и инициалы;
■ номер группы;
■ успеваемость (массив из пяти элементов).
Сможет любой смотря на готовый пример, даже мой рыжий кот если ему пример хороший показать.
0
Lek
1 / 1 / 0
Регистрация: 16.08.2010
Сообщений: 48
09.01.2012, 02:35  [ТС] #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. А дальше не пойму никак, се лабы сделал структуры никак не пойму.
0
CJS
49 / 49 / 4
Регистрация: 17.07.2011
Сообщений: 379
09.01.2012, 03:32 #4
Вот так структура объявляется , это то, что сразу бросилось в глаза.

C
1
2
3
4
5
6
7
8
struct STUDENT
{
char familiya[15];
char gr[15];
int ysp;
 
};
struct STUDENT  zapis[4];
0
Gepar
1177 / 533 / 20
Регистрация: 01.07.2009
Сообщений: 3,517
09.01.2012, 14:34 #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 и выше
}
1
Infinity3000
1058 / 577 / 24
Регистрация: 03.12.2009
Сообщений: 1,255
06.03.2012, 19:59 #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;
}
0
Миниатюры
Структура с именем STUDENT (эпизод 1001)  
Вложения
Тип файла: txt inform.txt (460 байт, 38 просмотров)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.03.2012, 19:59
Привет! Вот еще темы с ответами:

Описать структуру с именем STUDENT - C++
Описать структуру с именем STUDENT, содержащую следующие поля: фамилии и инициалы; • номе группы; • успеваемость (массив и пят...

Описать структуру с именем STUDENT - C++
// sub22.cpp: определяет точку входа для консольного приложения. //Вариант 1 //1. Описать структуру с именем STUDENT, содержащую...

Описать структуру с именем STUDENT - C++
как подогнать это 1. Описать структуру с именем STUDENT, содержащую следующие поля: • NAME - фамилия и инициалы; • GROUP- номер...

Описать структуру с именем STUDENT - C++
1. Описать структуру с именем STUDENT, содержащую следующие поля: фамилия и инициалы; номер группы; успеваемость (массив из пяти...


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

Или воспользуйтесь поиском по форуму:
7
Yandex
Объявления
06.03.2012, 19:59
Ответ Создать тему
Опции темы

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