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

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

Войти
Регистрация
Восстановить пароль
 
Holodov
5 / 5 / 0
Регистрация: 01.10.2011
Сообщений: 46
#1

Как сделать чтобы значение n сохранилось для всех функций? - C++

31.10.2011, 18:28. Просмотров 311. Ответов 4
Метки нет (Все метки)

Доброго времени суток. Интересует такой вопрос. Нужно реализовать что-то подобное

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
void create(table *str,int n)
{
    int i=0;
    char p[]=".";
    ofstream out;
    out.open("database.txt");
    if(!out.is_open()){cout<<"Ошибка! Файл не создан.";exit(1);}
    system("cls");
    for(i=0;i<n;i++)
    {
        
        cout<<"Введите фамилию"<<endl;
        cin>>str[i].name;
        cout<<endl;
        out<<"\t"<<str[i].name<<"\t";
        if(strcmp(str[i].name,p)==NULL)
        {
            break;
        }
 
        cout<<"Введите подразделение"<<endl;
        cin>>str[i].otdel;
        cout<<endl;
        out<<"\t"<<str[i].otdel<<"\t";
 
        cout<<"Введите категорию вредности от 1 до 3"<<endl;
        cin>>str[i].vred;
        cout<<endl;
        out<<"\t"<<str[i].vred<<"\t";
 
        cout<<"Введите должность"<<endl;
        cin>>str[i].dolj;
        cout<<endl;
        out<<"\t"<<str[i].dolj<<"\t";
 
        cout<<"Введите оклад"<<endl;
        cin>>str[i].oklad;
        cout<<endl;
        out<<"\t"<<str[i].oklad<<"\t";
 
        str[i].premia=(str[i].oklad*(10*str[i].vred))/100;
            cout<<endl;
        out<<"\t"<<str[i].premia<<"\t";
 
        
        
    }
    
    out.close();
    system("cls");
    cout<<n;
}
 
void read(table *str,int n)
{   
    int i=0;
    int c=4;
    HANDLE hCon;                     // Задал имя заголовка который будет использовать в дальнейшем
    COORD cPos;                       // Задал координаты X и Y. Тип Short - целочисленный знаковый тип
        
        hCon = GetStdHandle(STD_OUTPUT_HANDLE); //    Кто точно знает как обозвать что тут происходит
                                                                       //    пусть напишет.
    ifstream in;
    in.open("database.txt");
    if(!in.is_open())
    {cout<<"Ошибка! Файл не может быть найден/открыт.";exit(1);}
    system("cls");
    cout<<"#############################################################################\n";
    cout<<"#   Фамилия    #   Отдел   # Кат.вредн #    Должность    #  Оклад  # Премия #\n";
    cout<<"#############################################################################\n";
    
    for(i=0;i<n;i++)
    { 
        c=i+4;
    
        
        cPos.Y = c;
        cPos.X = 1;    
        SetConsoleCursorPosition(hCon, cPos);
        in>>str[i].name;
        cout<<str[i].name;
        cPos.Y = c;
        cPos.X = 16;
        SetConsoleCursorPosition(hCon, cPos);
        in>>str[i].otdel;
        cout<<str[i].otdel;
        cPos.Y = c;
        cPos.X = 33;
        SetConsoleCursorPosition(hCon, cPos);
        in>>str[i].vred;
        cout<<str[i].vred;
        cPos.Y = c;
        cPos.X = 40;
        SetConsoleCursorPosition(hCon, cPos);
        in>>str[i].dolj;
        cout<<str[i].dolj;
        cPos.Y = c;
        cPos.X = 58;
        SetConsoleCursorPosition(hCon, cPos);
        in>>str[i].oklad;
        cout<<str[i].oklad;
        cPos.Y = c;
        cPos.X = 68;
        SetConsoleCursorPosition(hCon, cPos);
        in>>str[i].premia;
        cout<<str[i].premia;
        cout<<endl;
        
    }
    in.close();
    system("PAUSE");
    system("cls");
}
void search(table *str,int n)
{   
    char f[14];
    int c=4;
    int i=0;
    int k=0;
    HANDLE hCon;                     // Задал имя заголовка который будет использовать в дальнейшем
    COORD cPos;                       // Задал координаты X и Y. Тип Short - целочисленный знаковый тип
        
        hCon = GetStdHandle(STD_OUTPUT_HANDLE); 
                                                                     
    ifstream in;
    in.open("database.txt");
    if(!in.is_open())
    {cout<<"Ошибка! Файл не может быть найден/открыт.";exit(1);}
    system("cls");
    cout<<"Введите фамилию: ";
    cin>>f;
    while(i<n)
    {
    in>>str[i].name;
    if(strcmp(str[i].name,f)==0){
        cout<<i;
                    k=k+1;
                    c=i+4;
                    system("cls");
                    cout<<"#############################################################################\n";
                    cout<<"#   Фамилия    #   Отдел   # Кат.вредн #    Должность    #  Оклад  # Премия #\n";
                    cout<<"#############################################################################\n";
                    cPos.Y = c;
                    cPos.X = 1;    
                    SetConsoleCursorPosition(hCon, cPos);
                    cout<<str[i].name;
                    cPos.Y = c;
                    cPos.X = 16;
                    SetConsoleCursorPosition(hCon, cPos);
                    in>>str[i].otdel;
                    cout<<str[i].otdel;
                    cPos.Y = c;
                    cPos.X = 33;
                    SetConsoleCursorPosition(hCon, cPos);
                    in>>str[i].vred;
                    cout<<str[i].vred;
                    cPos.Y = c;
                    cPos.X = 40;
                    SetConsoleCursorPosition(hCon, cPos);
                    in>>str[i].dolj;
                    cout<<str[i].dolj;
                    cPos.Y = c;
                    cPos.X = 58;
                    SetConsoleCursorPosition(hCon, cPos);
                    in>>str[i].oklad;
                    cout<<str[i].oklad;
                    cPos.Y = c;
                    cPos.X = 68;
                    SetConsoleCursorPosition(hCon, cPos);
                    in>>str[i].premia;
                    cout<<str[i].premia;
                    cout<<endl;
                
    }
    }               
    
    
                
 
 
 
            if(k==0) 
            cout<<"Совпадений нет"<<endl;
    in.close();
    cout<<"\n";
    system("PAUSE");
    system("cls");
}
Вот условие выхода из цикла.

C++
1
2
3
4
5
6
if(strcmp(str[i].name,p)==NULL)
        {
                        n=i;
            break;
                        
        }
Как сделать чтобы значение n сохранилось для всех функций?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
31.10.2011, 18:28
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Как сделать чтобы значение n сохранилось для всех функций? (C++):

Как сделать, чтобы экземпляр класса возвращал значение? - C++
так ifstream m(&quot;file&quot;); if(m)//&lt;&lt;&lt;===как заставить свой класс делать также { //действие }

Как сделать чтобы класс возвращал значение своего поля? - C++
Возможно я не верно выразился, есть класс: class Monstr { String name; int ammo; }; как сделать чтобы при: Monstr...

Алгоритм для нахождения всех булевых функций от N переменных - C++
Помогите придумать оптимальный алгоритм для данного условия! очень нужно плиз!!!!!!!(хотя бы для 4)

Как сделать отдельные записи в таблице по строкам, чтобы сделать запросы? - C++
Вот моя программа.. она производит чтение, только символами... #include &lt;iostream&gt; #include &lt;fstream&gt; #include &lt;iomanip&gt; #include...

Используя рекурсию, сделать так, чтобы значение многочлена степеней выводилось от 0 до N - C++
Дана рекурентная формула:. Я вывел рекурсию, но как сделать, чтобы значение многочлена степеней выводилось от 0 до N. Прилаживаю код...

подскажите как сделать чтобы программа работала и выводила информацию о рейсах которыми можно воспользоваться для прибытия в пункт назначения раньше з - C++
в справочной автовокзала хранится расписание движения автобусов. Для каждого рейса указаны его номер, тип автобуса, пункт назначения, время...

4
Frequencies
0 / 0 / 2
Регистрация: 25.09.2011
Сообщений: 49
31.10.2011, 19:08 #2
сделать его константным?
0
VenCarbon
33 / 32 / 3
Регистрация: 14.12.2010
Сообщений: 158
31.10.2011, 19:21 #3
Если я правильно поняла вас, то нужно сделать так:

C++
1
2
3
void plusPlus(int *n) {
  n++;
}
тогда вызов будет делаться так:

C++
1
2
int n = 7;
plusPlus(&n); // дальше уже n = 8;
1
Holodov
5 / 5 / 0
Регистрация: 01.10.2011
Сообщений: 46
31.10.2011, 19:34  [ТС] #4
Спасибо , понял.
А сделал так , просто дописал в каждую функцию это условие
0
co6ak
Кошковед
409 / 502 / 29
Регистрация: 12.04.2010
Сообщений: 1,392
31.10.2011, 20:21 #5
второй вариант - сделать переменную глобальной. стоит избегать его всеми возможными способами. но опять же, случаи бывают разные
0
31.10.2011, 20:21
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
31.10.2011, 20:21
Привет! Вот еще темы с ответами:

В классе Date сделать так, чтобы IncrementDate принимал параметром отрицательное значение - C++
Используйте класс Date. Он принимает число дней в диапазоне 0-365, добавляет его к текущей дате и возвращает объект, имеющий новую дату....

Подскажите, почему значению функции присваивается true? Что сделать чтобы передавалось значение? - C++
#include&lt;iostream&gt; #include&lt;math.h&gt; using namespace std; template&lt;typename T&gt; T f1(T a, T b) { if (a == 0){ cout &lt;&lt; &quot;no...

Как сделать с использованием функций? - C++
#include &lt;iostream&gt; using namespace std; #include &lt;cmath&gt; int main() {

Вычислить сумму ряда. Для сравнения найти точное значение функций - C++
\frac{1}{2}-\frac{1}{4}+\frac{1}{8}-\frac{1}{16}+\frac{1}{32}-...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

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