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

Проблема с рандомом + помощь в создании алгоритма - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Из цифр в буквы http://www.cyberforum.ru/cpp-beginners/thread335039.html
Скажите как перейти из цифрового номера буквы в ANSI обратно в букву. Как букву в цифру превратить я знаю cout<<(int)'A';
C++ Решение суммы ряда Не раз видел задачки типа "Дано вещественное число Х и целое число N (>0).Найти значение выражения 1-х^2/(2!)+x^4/(4!)-...+(-1)^n*X^(2*n)/((2*N)!) (N!=1*2*...*N). ... " , не понимал и откладывал в "дальний угол". Т.в. прошу, объясните подробно, как их решать? На что смотреть в первую очередь? Как я понимаю формула строится по последней части (...+(-1)^n*X^(2*n)/((2*N)!)), скорее всего я не... http://www.cyberforum.ru/cpp-beginners/thread335033.html
Русский язык в консоли C++
Скажу сразу, что закрепленную тему я прочитал, но не очень понял, как это реализовать. Вот код, текст выводится неизвестными символами. Будьте добры, переделайте программу так, что отображался русский текст. Тогда на примере я и пойму, как его сделать. #include <iostream> using namespace std; int main() { cout << "Привет планета Земля\n"; system("PAUSE");
C++ Посоветуйте open source проект
Посоветуйте, пожалуйста, хороший open-source проект на котором можно поучиться. Критерии: 1. Лицензия GNU/GPL, BSD etc. 2. Основные языки C/C++ 4. Платформа - Windows 3. Хорошая документация и структура 4. Качественный код 5. Невысокий уровень сложности 6. Русскоязычное сообщество разработчиков(опционально) Спс.
C++ Перемножение матриц. http://www.cyberforum.ru/cpp-beginners/thread334993.html
Нужен код для перемножения матрицы и столбца за минимально возможное время. Порядок матрицы ( и столбца ) огромен - около 100000. Помогите найти оптимальный код! Ищу уже 2 день... что-то безрезультатно как то(((
C++ Одномерный массив Удалить из одномерного массива все повторяющиеся элементы, оставив их первые вхождения, т.е в массиве должны остаться только различные элементы. подробнее

Показать сообщение отдельно
nikitos9305
0 / 0 / 0
Регистрация: 08.03.2011
Сообщений: 44
21.07.2011, 16:22     Проблема с рандомом + помощь в создании алгоритма
Такая штука - делаю одну прогу (игра напоминающая бомбермен)...
Решил отдельнонаписать прожку в которой юзер начинает матч - боты сами ходят и коцают друг друга ...
ПРОБЛЕМА, только и заключаеться в том, что движения их порой вызываю подозрения - наблюдаеться некая синхронность...
Подскажите пожалуйста в чем проблема + подкиньте плз идею того, как реализовать движения ботов в соответствии с рассположением иных (тобиш как запрограмировать движение бота в направлении другого бота с целью уничтожения ) ?
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
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
[CPP]#include <iostream>
#include <cstdlib>
#include <fstream>
#include <conio.h>
#include <ctime>
#include <dos.h>
#include <windows.h>
 
using namespace std;
 
char mas_pole[1000];
int ratz_num;  // количество ratz
int ratz_num_1;
int ratz_places[8]; // это масив индексов(max их может быть 8) mas_pole[] которые задают рассположение ratz в даный момент процеса
 
char ratz_lives[8];
 
int last;
 
int killer; // встречаеться в функциях
int prey;
char x;
int k_1;
 
 
void show_mas(char *mas_1, int k)   // cout<< massive changed
{
    int t_1 =0;
    while (t_1<k)
    {
        if(mas_pole[t_1]=='1')cout<<(char)2;
        if(mas_pole[t_1]=='0')cout<<' ';
        if(mas_pole[t_1]=='9')cout<<(char)219;
        if(mas_pole[t_1]=='2')cout<<(char)197;
        if((int)mas_pole[t_1]==10) cout<<'\n';
        t_1++;
    }
 
    cout<<"\n\n\n";
}
 
void show_original_mas ( char *mas_2, int k_1)    // cout<<  original massive
{
    int t_2=0;
    while (t_2<k_1){cout<<mas_2[t_2]; t_2++;}
    cout<<"\n\n\n";
}
 
 
 
 
//Movement Functions
 
 
void move_up(char *mas_3, int &place)
{
 
    if(mas_3[place-last]=='1')
    {
        k_1=0;
        mas_3[place-last]='2';
        while (k_1<ratz_num)
              {
                  if(place==ratz_places[k_1]) killer=k_1+1;
                  if(place-last==ratz_places[k_1])prey=k_1+1;
                  k_1++;
              }
        ratz_num_1--;
        ratz_lives[prey-1]=(char)197;
        ratz_places[prey-1]=0;
        cout<<"Ratz #"<<killer<<"  killed  Ratz # "<<prey<<'\n';
    }
    else if (mas_3[place-last]=='0')
            {
                x=mas_3[place];
                mas_3[place]=mas_3[place-last];
                mas_3[place-last]=x;
                k_1=0;
                while (k_1<ratz_num)
                {
                    if(place==ratz_places[k_1]) ratz_places[k_1]=place-last;
                    k_1++;
                }
 
            }
 
}
 
void move_down(char *mas_4, int &place_1)
{
 
    if(mas_4[place_1+last]=='1')
    {
        k_1=0;
        mas_4[place_1+last]='2';
        while (k_1<ratz_num)
              {
                  if(place_1==ratz_places[k_1]) killer=k_1+1;
                  if(place_1+last==ratz_places[k_1])prey=k_1+1;
                  k_1++;
              }
        ratz_num_1--;
        ratz_lives[prey-1]=(char)197;
        ratz_places[prey-1]=0;
        cout<<"Ratz #"<<killer<<"  killed  Ratz # "<<prey<<'\n';
    }
    else if (mas_4[place_1+last]=='0')
            {
                x=mas_4[place_1];
                mas_4[place_1]=mas_4[place_1+last];
                mas_4[place_1+last]=x;
                k_1=0;
                while (k_1<ratz_num)
                {
                    if(place_1==ratz_places[k_1]) ratz_places[k_1]=place_1+last;
                    k_1++;
                }
 
            }
 
}
 
void move_left(char *mas_5, int &place_2)
{
    int k_1;
 
 
    if(mas_5[place_2-1]=='1')
    {
        k_1=0;
        mas_5[place_2-1]='2';
        while (k_1<ratz_num)
              {
                  if(place_2==ratz_places[k_1]) killer=k_1+1;
                  if(place_2-1==ratz_places[k_1])prey=k_1+1;
                  k_1++;
              }
        ratz_num_1--;
        ratz_lives[prey-1]=(char)197;
        ratz_places[prey-1]=0;
        cout<<"Ratz #"<<killer<<"  killed  Ratz # "<<prey<<'\n';
    }
    else if (mas_5[place_2-1]=='0')
            {
                x=mas_5[place_2];
                mas_5[place_2]=mas_5[place_2-1];
                mas_5[place_2-1]=x;
                k_1=0;
                while (k_1<ratz_num)
                {
                    if(place_2==ratz_places[k_1]) ratz_places[k_1]=place_2-1;
                    k_1++;
                }
 
            }
 
}
 
void move_right(char *mas_6, int &place_3)
{
    int k_1;
    int killer;
    int prey;
    char x;
 
    if(mas_6[place_3+1]=='1')
    {
        k_1=0;
        mas_6[place_3+1]='2';
        while (k_1<ratz_num)
              {
                  if(place_3==ratz_places[k_1]) killer=k_1+1;
                  if(place_3+1==ratz_places[k_1])prey=k_1+1;
                  k_1++;
              }
        ratz_num_1--;
        ratz_lives[prey-1]=(char)197;
        ratz_places[prey-1]=0;
        cout<<"Ratz #"<<killer<<"  killed  Ratz # "<<prey<<'\n';
    }
    else if (mas_6[place_3+1]=='0')
            {
                x=mas_6[place_3];
                mas_6[place_3]=mas_6[place_3+1];
                mas_6[place_3+1]=x;
                k_1=0;
                while (k_1<ratz_num)
                {
                    if(place_3==ratz_places[k_1]) ratz_places[k_1]=place_3+1;
                    k_1++;
                }
 
            }
 
}
 
 
 
 
 
 
 
// General function of movements
 
 
void move(char *mas_2,int &place_r)
{
    int direction ;
    srand( (unsigned)time(NULL) );
    here_1:direction = rand()%4;
 
    if (direction==0)
    {
        if(mas_2[place_r-last]=='9'||mas_2[place_r-last]=='2')goto here_1;
        else move_up(mas_2,place_r);
    }
    if (direction==1)
    {
       if(mas_2[place_r+last]=='9'||mas_2[place_r+last]=='2')goto here_1;
       else move_down(mas_2,place_r);
    }
    if (direction==2)
    {
        if(mas_2[place_r+1]=='9'||mas_2[place_r+1]=='2')goto here_1;
        else move_right(mas_2,place_r);
    }
    if (direction==3)
    {
        if(mas_2[place_r-1]=='9'||mas_2[place_r-1]=='2')goto here_1;
        else move_left(mas_2,place_r);
    }
}
 
 
 
int main()
{
    ifstream fi("battlefield.txt");
 
    if ( fi.fail() ) {cout<<fi.fail()<<" - Failure !!!\n";}   // check stream
    else cout << "Everything's OK !!!\n";
 
 
 
 
    int t=0;
    int i=0;
    int need=1;
    char ch;
 
    fi>>noskipws;
    while (fi >> ch)
    {
        mas_pole[t]=ch;
        if ((int)mas_pole[t]==10 && need ) {last=t+1; need=need-1;}
        if(mas_pole[t]=='1'){ratz_places[i]=t;ratz_lives[i]=(char)3;i++;}  //написано для <= 8 ratz...
        t++;
    }
 
 
    ratz_num=i;
    ratz_num_1=ratz_num;
    if (ratz_num==0) {cout << "No Ratz !!!\n Good Bye :]"; system("pause");exit(1);}
 
    cout<<"Here is the map\n\n\n";
 
    show_mas(mas_pole,t);
    show_original_mas(mas_pole,t);
    i=0;
    cout<<"Length of line : "<<last<<'\n';
    cout<<"Number of Ratz : "<<ratz_num<<'\n';
    cout<<"Ratz locations : "; while (i<ratz_num){cout<<ratz_places[i]<<' ';i++;}
 
    int count;
    char your_turn;
    char answer;
    int info=1;
 
 
 
        int n_1;
        count=0;
        here :
        if(info){cout<<"\n Welcome to the new paradime of entertainment !!!\n Please press :\nx  - to exit\ng  - to start mayhem !!!\n";info=0;}
 
        your_turn=getch();
 
 
 
          if(your_turn=='x')
          {
               cout<<"You've just pressed 'x': Do you want to exit (y/n) ?\n";
               answer=getch();
               if(answer=='y') {cout<<"Good bye !!! \n"; system("pause"); exit(1);}
               else {cout<<"So we continue the mayhem !!!\n";goto here;}
          }
 
          else if(your_turn=='g') {
 
 
                                    while (ratz_num_1!=1 && !kbhit())
                                   {
                                count=0;
                                while (count<ratz_num ){if (ratz_places[count]!=0) move(mas_pole,ratz_places[count]);count++;}
 
 
                                   system("cls");
                                   show_mas(mas_pole,t);
                                   show_original_mas(mas_pole,t);
                                   n_1=0;
                                   while (n_1<ratz_num) {cout<< "Ratz #"<<n_1+1 <<'['<<ratz_lives[n_1]<<']'<<'\n';n_1++;}
                                   Sleep(100);
 
                                  }
                                  }
 
               else {cout << "You've probably pressed the wrong key\n";info =1; goto here;}
 
 
 
 
 
 
 
 
 
    cout<< "The winner is Ratz # ";
    int survivour=0;
    while(survivour<ratz_num) {if(ratz_places[survivour]!=0)cout<<survivour+1<<'\n';survivour++;}
 
 
 
 
 
 
    system ("pause");
    return 0;
}
[/CPP]
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 23:38. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru