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

Нужны коментарии. - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ BFS. Путь из вершины в нее саму http://www.cyberforum.ru/cpp-beginners/thread284780.html
Неверно выводит путь из вершину в нее же саму, то есть из 5 в 5 путь равен 2, остальное все верно считает #include <iostream> using namespace std; const int m=50; int n;// число вершин графа int mass;//матрица смежности int ways;//массив кратчайших путей int q; int st, en,tail,head ;//стартовая и конечная вершины //процедура получает на вход номер стартовой вершины
C++ работа с файлами как прочитать файл и переписать его в другой только что бы символы каждой строки были в обратном порядке... ну как бы зеркальное отражение http://www.cyberforum.ru/cpp-beginners/thread284776.html
что нужно заметить для того чтобы получился прямоугольник ? C++
И так, это код в цикле do_while показывающий на экране квадрат сторонами 5*5 с этим я справился, теперь , что нужно заметить для того чтобы получился прямоугольник ? не важно с какими сторонами...потом прошк объяснить как квадрат вписать в прямоугольник.... я сделал квадрат с циклом do while если превращать в треугольник то можно использовать или do while или while либо for... если кто то может...
C++ Дано текст. Найти самое длинное слово.
Нужна ваша помощь. Прога должна быть на языке С. Дано текст. Найти самое длинное слово.
C++ работа с файлами http://www.cyberforum.ru/cpp-beginners/thread284758.html
подскажите как считывать с ini файла в массив структур
C++ Найти количество автомобилей каждый марки. Даны сведения об автомобиле: ФИО владельца, стоимость, марка и номер автомобиля. Найти количество автомобилей каждый марки.( задача на языке си) подробнее

Показать сообщение отдельно
volodia-h
2 / 2 / 0
Регистрация: 02.03.2010
Сообщений: 76
27.04.2011, 22:05     Нужны коментарии.
Программа, моделирующая проведения спортивных соревнований между футбольными командами.
Кому не лень прокоментируйте.
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
#include <windows.h>
#include <iostream.h>
#include <fstream.h>
#include <sstream.h>
#include <string.h>
#include <iomanip.h>
#include <set.h>
 
using namespace std;
 
const int win_points = 3;
const int draw_points = 1;
 
struct STeam
{
  string name;
  int part;
  int wins;
  int draws;
  int loses;
  int goals_for;
  int goals_after;
  int points;
 
 STeam(const string in_name, const int in_part, const int in_wins,
        const int in_draws, const int in_loses, const int in_goals_for,
        const int in_goals_after, const int in_points)
  {
    name  = in_name;
    part  = in_part;
    wins  = in_wins;
    draws = in_draws;
    loses = in_loses;
    goals_for   = in_goals_for;
    goals_after = in_goals_after;
    points = in_points;
  }
 
  STeam(const string in_name)
  {
    name  = in_name;
  }
 
  void update(const int in_wins, const int in_draws, const int in_loses,
              const int in_goals_for, const int in_goals_after,
              const int in_points)
  {
    part++;
    wins  += in_wins;
    draws += in_draws;
    loses += in_loses;
    goals_for   += in_goals_for;
    goals_after += in_goals_after;
    points += in_points;
  }
 
  bool operator<(const STeam& O) const
  {
    return name < O.name;
  }
};
 
typedef set<STeam> STeams;
 
bool read_records(STeams &teams, char *fname)
{
  ifstream in(fname);
 
  if( !in.is_open() )
  {
    cout << "ГЋГёГЁГЎГЄГ* ïðè îòêðûòèè ГґГ*éëГ* " << fname << endl;
    return false;
  }
 
  string name1, name2;
  int wins;
  int draws;
  int loses;
  int goals_for;
  int goals_after;
  int points1, points2;
 
  while(!in.eof())
  {
    in >> name1 >> name2 >> goals_for >> goals_after;
    if(goals_for==goals_after)
    {
      wins  = 0;
      draws = 1;
      loses = 0;
      points1 = draw_points;
      points2 = draw_points;
    }
    else if(goals_for<goals_after)
    {
      wins  = 0;
      draws = 0;
      loses = 1;
      points1 = 0;
      points2 = win_points;
    }
    else
    {
      wins  = 1;
      draws = 0;
      loses = 0;
      points1 = win_points;
      points2 = 0;
    }
    STeams::iterator it = teams.find(name1);
    if(it!=teams.end())
      (*it).update(wins, draws, loses, goals_for, goals_after, points1);
    else
      teams.insert(STeams::value_type(name1, 1, wins, draws, loses, goals_for, goals_after, points1));
    it = teams.find(name2);
    if(it!=teams.end())
      (*it).update(loses, draws, wins, goals_after, goals_for, points2);
    else
      teams.insert(STeams::value_type(name2, 1, loses, draws, wins, goals_after, goals_for, points2));
  }
 
  return true;
}
 
int compare( const void *arg1, const void *arg2 )
{
   if((*(STeams::iterator *)arg1)->points==(*(STeams::iterator *)arg2)->points)
     return strcmp((*(STeams::iterator *)arg1)->name.c_str(), (*(STeams::iterator *)arg2)->name.c_str());
   else
     return (*(STeams::iterator *)arg2)->points - (*(STeams::iterator *)arg1)->points;
}
 
void write_table(STeams &teams, char *fname)
{
  int n = teams.size();
 
  STeams::iterator *ip = new STeams::iterator[n];
  int num = 0;
  for(STeams::iterator it = teams.begin(); it!=teams.end(); it++)
  {
    ip[num++] = it;
  }
  qsort((void *)ip, n, sizeof(STeams::iterator), compare);
 
 
  ofstream outFile(fname);
  if(!outFile.good())
  {
    cout << "ГЋГёГЁГЎГЄГ* ïðè îòêðûòèè âûõîäГ*îãî ГґГ*éëГ*!" << endl;
    delete[] ip;
    return;
  }
  num = 0;
  for(num = 0; num < n; num++)
  {
    outFile << setw(2) << right << num+1 << ". " << setw(12) << left << ip[num]->name
      << right << setw(3) << ip[num]->part
      << setw(3) << ip[num]->wins
      << setw(3) << ip[num]->draws
      << setw(3) << ip[num]->loses
      << setw(3) << ip[num]->goals_for << " -"
      << setw(3) << ip[num]->goals_after
      << setw(3) << ip[num]->points
      << endl;
  }
 
  delete[] ip;
}
 
 
 
int main(int argc, char* argv[])
{
  STeams teams;
 
  if(read_records(teams, "turnir.txt"))
    write_table(teams, "result.txt");
 
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 18:33. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru