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

База данных студентов (массивы) - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ структура элемента массива аттестационная карточка : фамилия, имя, отчество, номер курса, факультет, увеличения, 1- http://www.cyberforum.ru/cpp-beginners/thread1140390.html
структура элемента массива аттестационная карточка : фамилия, имя, отчество, номер курса, факультет, увеличения, 1-ый семестр (теория алгоритмов, физика, история), 2-ой семестр (программирование, физика, черчение). по аттестационным карточкам группы определить , что увлекаются шахматами, и имеют не меньше двух отличных оценок в каждой сессии. С/С++
C++ Ошибка в формуле не могу исправить http://www.cyberforum.ru/attachment.php?attachmentid=385415&stc=1&d=1396783612 #include <vcl.h> #pragma hdrstop #include <stdio.h> #include <math.h> #pragma argsused int main(int argc, char* argv) {float a, b, x, F; int i; http://www.cyberforum.ru/cpp-beginners/thread1140385.html
C++ Как можно сравнивать в структуре числа и выводить на экран по возрастанию, если структура находится в файле?
Как можно сравнивать в структуре числа и выводить на экран по возрастанию, если структура находится в файле?
C++ Ошибка в методе обрабатывающем бинарное дерево
Есть метод обрабатывающий бинарное дерево и состовляющий двумерный массив указателей на листья, так что в первой строке - указатель на root, во второй - листья второго уровня и так далее. Вот сам метод: void view_alternative(tree* root){ tree* b; for(int i = 0; i < 50; i++) for(int j = 0; j < 50; j++) b = NULL; int n = 0, m = 1, m1; b = root; while(m != 0){
C++ Обработка массива/С++ для начинающих http://www.cyberforum.ru/cpp-beginners/thread1140370.html
Сформувати випадковим чином масив із 20 елементів. Сформувати новий масив так, щоб кожен n -ий елемент цього масиву дорівнював сумі квадратів (n-1) -го та (n+1) -го елементів початкового масиву, якщо хоча б один із них від’ємний, або добутку (n-1) -го та (n+1) -го елементів початкового масиву в іншому випадку. Перший і двадцятий елементи залишити такими ж, як у початковому масиві....
C++ Для каждого слова определить количество вхождений в исходном тексте Помогите, пожалуйста: Задан произвольный текст. Слова в тексте могут разделяться одним или несколькими пробелами, знаками пунктуации и переходами на следующую строку. Каждое слово размещается в одной и той же строке (переносы слов не используются). Выполнить следующие действия: * Выделить каждое отдельное слово, входящее в текст. * Для каждого слова определить количество вхождений в... подробнее

Показать сообщение отдельно
Hrollo
34 / 34 / 6
Регистрация: 05.11.2013
Сообщений: 147
06.04.2014, 18:31     База данных студентов (массивы)
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
#include <iostream>
#include <string>
 
 
using namespace std;
 
struct Student
{
    string name;
    string surname;
};
 
Student *add(Student *arr,int &s,const Student &st,const int m)
{
    if(s >= m)
        return arr;
    s++;
    Student *p = new Student[s];
    for(int i(0);i<s-1;i++)
        p[i]=arr[i];
    p[s-1]=st;
    delete []arr;
    return p;
}
 
Student *del(Student *arr,int &s,const Student &st)
{
    int index = -1;
    for(int i(0);i<s;i++)
    {
        if(arr[i].name == st.name && arr[i].surname == st.surname)
        {
            index = i;
            break;
        }
    }
    if(index ==(-1))
        return arr;
    s--;
    Student *p = new Student[s];
    int k = 0;
    for(int i(0);i<(s+1);i++)
    {
        if(index == i)
        {
            k++;
            continue;
        }
        p[i-k] = arr[i];
    }
    delete []arr;
    return p;
}
 
void show(Student *st,int size)
{
    if(size == 0)
    {
        cout<<"Group empty!"<<endl;
        return;
    }
    for(int i(0);i<size;i++)
        cout<<"Information for "<<i+1<<" student:"<<st[i].name<<" "<<st[i].surname<<endl;
}
 
int main()
{
    const int max = 70;
    int size = 0;
    Student *group = NULL;
    char ch;
    Student stud;
    int sw=0;
    do
    {
       cout<<"Your choice:"<<endl;
       cout<<"1 - add student"<<endl;
       cout<<"2 - delete student"<<endl;
       cout<<"3 - show group"<<endl;
       cin>>sw;
       switch(sw)
       {
       case 1:
           if(size == 0)
           {
               size++;
               group = new Student[size];
               cout<<"Input name:";
               cin>>group->name;
               cout<<"Input surname:";
               cin>>group->surname;
           }
           else
           {
               cout<<"Input name:";
               cin>>stud.name;
               cout<<"Input surname:";
               cin>>stud.surname;
               group = add(group,size,stud,max);
           }
           break;
       case 2:
           cout<<"Input name:";
           cin>>stud.name;
           cout<<"Input surname:";
           cin>>stud.surname;
           group = del(group,size,stud);
           break;
       case 3:
           show(group,size);
           break;
       default:
           break;
       }
       cout<<"Continue?(enter q to quit)";
       cin>>ch;
    }while(ch!='q');
    delete []group;
    return 0;
}
 
Текущее время: 12:23. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru