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

Объяснить как работает программа - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Двоичный код Хоффмана http://www.cyberforum.ru/cpp-beginners/thread323606.html
Помогите написать программу на С++ по заданному тексту задания(задание на фото)?
C++ Программа на С, которая вводит число типа int с клавиатуры, преобразует ее в строку (str), выводит на дисплей число и строку. Задача направленная на усвоение следующих понятий: прототип функции; заголовок функции; тело функции; параметры, принимаемые функцией (аргументы); параметр, возвращаемый функцией. При решении задач в... http://www.cyberforum.ru/cpp-beginners/thread323598.html
C++ Написать все целые, положительные, взаимно простые с m из отрезка [1;m-1].
написать все целые положительные взаимно простые с m из отрезка .
C++ Запись логических выражений
как сделать проверку && и || в одном if for(;i>0; i--) { if(a>0 && (b <0 || c<0 || d<0) z=0; } куда выходит оператор break?
C++ Что следует дальше за C++? http://www.cyberforum.ru/cpp-beginners/thread323557.html
Я вот уже несколько месяцев изучаю C++ самостоятельно дома ради собственного интереса. Както понравилось оно мне однажды складывать разные простинькие програмки вот ирешил изучать далие. Читаю сейчас...
C++ Шаблоны функций Добрый вечер! less.h #pragma once #include "StdAfx.h" //preconditions: //defined operator< template <typename elemType> class less подробнее

Показать сообщение отдельно
monkey_tree
0 / 0 / 0
Регистрация: 21.06.2011
Сообщений: 8

Объяснить как работает программа - C++

21.06.2011, 08:42. Просмотров 413. Ответов 0
Метки (Все метки)

объясните пжлста как работает, и что для чего используется
вот задание: имеется поток для 3 очередей. Заявки отсортированы по времени поступления в каждую очередь. НАписать прогу печатающую порядокв котором эти заявки будут обслуженны. Время обслуживания заявок одинаковое. формат вых файла: кол-во заявок в первой очереди, список моментов времени в которые они возникают, анологично для 2й и 3й. В вых файл для каждой обслуженной заявки печатается номер очереди и время прихода заявки

вход
3
1
5
7
2
2
10
11

выход
1 1
2 2
1 5
1 7
2 10
3 11


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
#include "stdafx.h"
using namespace std;
 
 
 
int _tmain(int argc, _TCHAR* argv[])
{
 
system("cls"); //Очищает содержимое экрана
char* Fname = "input.txt";
ifstream myin(in_Fname);
if (!myin.is_open()) // если нет файла прога закрывается
{
exit(1);
};
int startnum=0;
int tNum=0;
//создаем очереди
queue <int> FirstQ,SecondQ,ThirdQ;
int NumQueue=0;
//заносим данные в череди
while (!myin.eof())
{
myin>>startnum;
for (int i=0;i<startnum;++i)
{
if (myin>>tNum)
{
switch (NumQueue)
{
case 0:
FirstQ.push(tNum);
break;
case 1:
SecondQ.push(tNum);
break;
case 2:
ThirdQ.push(tNum);
break;
default:
break;
}
}
}
++NumQueue;
if (NumQueue>2)
break;
}
myin.close();
int OfFirstQ = EndQueue , OfSecondQ = EndQueue , OfThirdQ = EndQueue;
/*подсчитывает результат и выводим*/
do
{
//значение из первой очереди
if (!FirstQ.empty())
{
if (OfFirstQ==EndQueue)
{
OfFirstQ=FirstQ.front();
FirstQ.pop();
}
}
//значение из второй очереди
if (!SecondQ.empty())
{
if (OfSecondQ==EndQueue)
{
OfSecondQ=SecondQ.front();
SecondQ.pop();
}
}
//значение из третьей очереди
if (!ThirdQ.empty())
{
if (OfThirdQ==EndQueue)
{
OfThirdQ=ThirdQ.front();
ThirdQ.pop();
}
}
CorrectOutValueAndWrite (OfFirstQ,OfSecondQ,OfThirdQ);
} while (OfFirstQ != EndQueue || OfSecondQ != EndQueue || OfThirdQ != EndQueue);
return 0;
}
 
int CorrectOutValueAndWrite (int &OfFirstQ,int &OfSecondQ,int &OfThirdQ)
{
ofstream myout(out_Fname,ios::app);
if (!myout.is_open())
{
myout.close();
exit(1);
};
if ((OfFirstQ<=OfSecondQ && OfFirstQ<=OfThirdQ && OfFirstQ!=EndQueue && OfSecondQ!=EndQueue && OfThirdQ!=EndQueue) || (OfSecondQ==EndQueue && OfFirstQ<=OfThirdQ && OfFirstQ!=EndQueue) || (OfThirdQ==EndQueue && OfFirstQ<=OfSecondQ && OfFirstQ!=EndQueue) || (OfThirdQ==EndQueue && OfSecondQ==EndQueue && OfFirstQ!=EndQueue))
{
myout<<1<<" "<<OfFirstQ<<endl;
OfFirstQ=EndQueue;
myout.close();
return 0;
}
if ((OfSecondQ<=OfFirstQ && OfSecondQ<=OfThirdQ && OfFirstQ!=EndQueue && OfSecondQ!=EndQueue && OfThirdQ!=EndQueue) || (OfFirstQ==EndQueue && OfSecondQ<=OfThirdQ && OfSecondQ!=EndQueue) || (OfThirdQ==EndQueue && OfSecondQ<=OfFirstQ && OfSecondQ!=EndQueue) || (OfThirdQ==EndQueue && OfSecondQ!=EndQueue && OfFirstQ==EndQueue))
{
myout<<2<<" "<<OfSecondQ<<endl;
OfSecondQ=EndQueue;
myout.close();
return 0;
}
if ((OfThirdQ<=OfFirstQ && OfThirdQ<=OfSecondQ && OfFirstQ!=EndQueue && OfSecondQ!=EndQueue && OfThirdQ!=EndQueue) || (OfSecondQ==EndQueue && OfThirdQ<=OfFirstQ && OfThirdQ!=EndQueue) || (OfFirstQ==EndQueue && OfThirdQ<=OfSecondQ && OfThirdQ!=EndQueue) || (OfThirdQ!=EndQueue && OfSecondQ==EndQueue && OfFirstQ==EndQueue))
{
myout<<3<<" "<<OfThirdQ<<endl;
OfThirdQ=EndQueue;
myout.close();
return 0;
}
myout.close();
return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.