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

Не могу разобраться с отработкой циклов - C++

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 15, средняя оценка - 4.73
Fafle
 Аватар для Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 13:32     Не могу разобраться с отработкой циклов #1
Есть код:
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
#include <iostream>
#include <stdio.h>
#include <conio.h>
#include <string.h>
#define SIZE1 21
#define SIZE2 60
 
using namespace std;
void print(char ar[][60]) {
    int i = 1;
    int j = 1;
    int a, leng = 5;
    ar[i][j] = 'X';
    char *ar1 = new char[100];
    char *ar2 = new char[100];
    char *ar3 = new char[100];
    char *ar4 = new char[100];
    char *ar5 = new char[100];
    char *ar6 = new char[100];
    char *ar7 = new char[100];
    char *ar8 = new char[100];
    char *ar9 = new char[100];
    char *ar10 = new char[100];
    char *ar11 = new char[100];
    char *ar12 = new char[100];
    char *ar13 = new char[100];
    char *ar14 = new char[100];
    char *ar15 = new char[100];
    char *ar16 = new char[100];
    char *ar17 = new char[100];
    char *ar18 = new char[100];
    char *ar19 = new char[100];
    char *ar20 = new char[100];
    char *str[20] = {ar1, ar2, ar3, ar4, ar5, ar6, ar7, ar8, ar9, ar10, ar11, ar12, ar13, ar14, ar15, ar16, ar17, ar18, ar19, ar20};
    while (1 != 0) {
        for (int g = 0; g < SIZE1; g++)
            puts(ar[g]);
        a = getch();
        switch (a) {
            case 67:
                if ((j + 1) != SIZE2 - 2) {
                    ar[i][j + 1] = ar[i][j];
                    str[0] = &ar[i][j];
                    j++;
                } else {
                    ar[i][j - (SIZE2 - 4)] = ar[i][j];
                    str[0] = &ar[i][j];
                    j = j - (SIZE2 - 4);
                }
                break;
            case 66:
                if (i + 1 != SIZE1 - 1) {
                    ar[i + 1][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i++;
                } else {
                    ar[i - (SIZE1 - 3)][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i = i - (SIZE1 - 3);
                }
                break;
            case 65:
                if ((i - 1) != 0) {
                    ar[i - 1][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i--;
                } else {
                    ar[i + (SIZE1 - 3)][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i += SIZE1 - 3;
                }
                break;
            case 68:
                if ((j - 1) != 0) {
                    ar[i][j - 1] = ar[i][j];
                    str[0] = &ar[i][j];
                    j--;
                } else {
                    ar[i][j + (SIZE2 - 4)] = ar[i][j];
                    str[0] = &ar[i][j];
                    j += SIZE2 - 4;
                }
                break;
        }
         for (int v = leng+2; v > 0; v--)
            str[v] = str[v - 1];
        *str[leng+2] = ' ';
 
        system("cls");
        
    }
}
 
int main() {
    char ar[21][60];
 
    for (int i = 0; i < SIZE1; i++) {
        for (int j = 0; j < SIZE2; j++) {
            if (j == SIZE2 - 1)
                ar[i][j] = '\0';
            else {
                if ((i == 0) || (i == SIZE1 - 1) || (j == 0) || (j == SIZE2 - 2)) {
                    ar[i][j] = 'X';
                } else {
                    ar[i][j] = ' ';
                }
            }
        }
    }
    print(ar);
}
Блок мэйн создает и инициализирует Массив из строк размером SIZE1 на SIZE2, в функции принт создает массив указателей на наш массив строк, далее задается вечный цикл для отображения на экран нашего массива, к помощью оператора getch() мы задаем внесение изменение, в массив указателей мы заносим адрес измененной ячейки, цикл
C++
1
2
 for (int v = leng+2; v > 0; v--)
            str[v] = str[v - 1];
позволяет смещать адреса в массиве указателей, с помощью переменной leng мы задаем номер адреса в массиве указателей для возврата его в первоначальный вид. По логике вроде все "четко", но есть одно но, результат немного не тот, к примеру при leng =5 должен возвращаться в изначальный вид символ по адресу leng[4] который был изменен 5 витков цикла while назад, но увы этого не происходит...

Возможны некоторые ошибки в коде в плане синтаксиса, переделал вручную под винду с Линукса.
У самого уже мозг не варит 3 дня овыряюсь не могу ошибку найти, заранее спасибо.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.04.2011, 13:32     Не могу разобраться с отработкой циклов
Посмотрите здесь:

C++ не могу разобраться
C++ Не могу разобраться в С++
Не могу разобраться с отработкой рекурсивной функции C++
C++ не могу разобраться
Не могу разобраться C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Fafle
 Аватар для Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 16:07  [ТС]     Не могу разобраться с отработкой циклов #21
Вот использование остальных указателей
C++
1
*str[leng+2] = ' ';
Что касается незаконченности, то целиком код будет еще не понятней, попробуй скомпилировать, будет видна сути проги, я потом выложу сюда полный код, чисто что вы поржали как я изощряюсь

Добавлено через 57 секунд

Не по теме:

Цитата Сообщение от <jnf Посмотреть сообщение
Fafle, почему мне никто не отвечает? я новичок.
подожди, может кто и откликнется

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Fafle
 Аватар для Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 16:10  [ТС]     Не могу разобраться с отработкой циклов #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
#include <iostream>
#include <stdio.h>
#include <conio.h>
#include <string.h>
#define SIZE1 21
#define SIZE2 60
 
using namespace std;
 
void print(char ar[][60]) {
    int i = 1;
    int j = 1;
    int a, leng = 12;
    ar[i][j] = 'X';
    char *str[50];
    for (int m = 0;m < 50; m++)
        str[m] = new char[100];
    while (1 != 0) {
        for (int g = 0; g < SIZE1; g++)
            puts(ar[g]);
        a = getch();
        switch (a) {
            case 67:
                if ((j + 1) != SIZE2 - 2) {
                    ar[i][j + 1] = ar[i][j];
                    str[0] = &ar[i][j];
                    j++;
                } else {
                    ar[i][j - (SIZE2 - 4)] = ar[i][j];
                    str[0] = &ar[i][j];
                    j = j - (SIZE2 - 4);
                }
                break;
            case 66:
                if (i + 1 != SIZE1 - 1) {
                    ar[i + 1][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i++;
                } else {
                    ar[i - (SIZE1 - 3)][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i = i - (SIZE1 - 3);
                }
                break;
            case 65:
                if ((i - 1) != 0) {
                    ar[i - 1][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i--;
                } else {
                    ar[i + (SIZE1 - 3)][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i += SIZE1 - 3;
                }
                break;
            case 68:
                if ((j - 1) != 0) {
                    ar[i][j - 1] = ar[i][j];
                    str[0] = &ar[i][j];
                    j--;
                } else {
                    ar[i][j + (SIZE2 - 4)] = ar[i][j];
                    str[0] = &ar[i][j];
                    j += SIZE2 - 4;
                }
                break;
        }
        for (int v = leng + 2; v > 0; v--)
            str[v] = str[v - 1];
        *str[leng + 2] = ' ';
 
        system("cls");
 
    }
}
 
int main() {
    char ar[21][60];
 
    for (int i = 0; i < SIZE1; i++) {
        for (int j = 0; j < SIZE2; j++) {
            if (j == SIZE2 - 1)
                ar[i][j] = '\0';
            else {
                if ((i == 0) || (i == SIZE1 - 1) || (j == 0) || (j == SIZE2 - 2)) {
                    ar[i][j] = 'X';
                } else {
                    ar[i][j] = ' ';
                }
            }
        }
    }
    print(ar);
}
то что есть сейчас, потом это обрастет до полноценной проги
Переменная leng будет изменяться и указывает длину змеи
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 16:13     Не могу разобраться с отработкой циклов #23

Не по теме:

Цитата Сообщение от <jnf Посмотреть сообщение
может я там непрвильно отправила?
Блин, дай ссылку, я тебе что-нибудь напишу там.


 Комментарий модератора 
Желающие могуть помочь по ссылке многослойный персептрон


Добавлено через 2 минуты
оК. Скомпилировал, запустил, не упало ничего.
В чём ошибка и как её повторить?
Fafle
 Аватар для Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 16:20  [ТС]     Не могу разобраться с отработкой циклов #24
Цитата Сообщение от Deviaphan Посмотреть сообщение

Не по теме:


Блин, дай ссылку, я тебе что-нибудь напишу там.



Добавлено через 2 минуты
оК. Скомпилировал, запустил, не упало ничего.
В чём ошибка и как её повторить?
Поиграйся с переменной leng, по логике она отвечает за длину змеи и должна при увеличении на 1 увеличивать змею на 1, но для увеличения змеи нужно ее увеличить на 3, но мы привязаны к массиву указателей вызывая из него
C++
1
*str[leng+2] = ' ';
На +2 не зацикливайся, это был шаманский обряд

Не по теме:

Я надеюсь теперь индусский код обретает смысл? А то я начинаю за себя бояться

Nameless One
02.04.2011, 16:22
  #25

Не по теме:

Fafle, главное - стремиться к совершенству

Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 16:24     Не могу разобраться с отработкой циклов #26
Добавь в цикл
C++
1
2
        case 'q':
            return;
Чтоб хоть выйти можно было.)

При любом leng у меня только рамка и Х в левом верхнем углу.
Fafle
 Аватар для Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 16:32  [ТС]     Не могу разобраться с отработкой циклов #27
Замени 65 66 67 68 на 119 115 100 97 и пользоваться w s d a для управления, у меня просто линь и ASCII таблица другая
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 17:33     Не могу разобраться с отработкой циклов #28
Ага, заработало.
НАписал бы case 'w' и т.п. и не пудрил мозги.)))

Добавлено через 8 минут
А прикольно.)
Раз уж я компилятор всё равно включил, напишу по другому.)

Добавлено через 40 минут
Но мерцает сильнее, т.к. я посимвольно пишу.
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
#include <conio.h>
#include <list>
 
#define SIZE1 21
#define SIZE2 60
 
typedef std::pair<int,int> Link;
typedef std::list<Link> Snake;
 
Link operator+ ( Link lhs, const Link & rhs )
{
    lhs.first += rhs.first;
    lhs.second += rhs.second;
    return lhs;
}
 
bool SnakeHere(const Snake & s, int w, int h )
{
    for( Snake::const_iterator ii = s.begin(); ii != s.end(); ++ii )
    {
        if( ii->first == w && ii->second == h )
            return true;
    }
 
    return false;
}
 
void Play()
{
    Snake snake;
    const int linkCount = 10;
 
    for( int i = 0; i < linkCount; ++i )
        snake.push_back( Link(i+1,1) );
 
    Link dir;
 
    while( true )
    {
        system("cls");
        
        for( int h = 0; h < SIZE1; ++h )
        {
            for( int w =0; w < SIZE2; ++w )
            {
                const bool edge = h == 0 || h == (SIZE1-1) || w == 0 || w == (SIZE2-1);
                if( edge )
                    putch( 'W' );
                else  if( SnakeHere( snake, w, h ) )
                    putch( 'O' );
                else
                    putch( ' ' );
            }
            putch( '\n' );
        }
 
        switch( _getch() )
        {
        case 'q':
            return;
        case 'w':
            dir = Link(0,-1);
            break;
        case 'a':
            dir = Link(-1,0);
            break;
        case 'd':
            dir = Link(1,0);
            break;
        case 's':
            dir = Link(0,1);
            break;
        };
 
        snake.pop_front();
        snake.push_back( snake.back() + dir );
    };
 
}
 
int main() {
    Play();
    return 0;
}
Добавлено через 38 секунд
И никаких проверок естессно не делаю.)
Fafle
 Аватар для Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 17:36  [ТС]     Не могу разобраться с отработкой циклов #29
Ну по другому мне тоже будет интересно посмотреть, н оне забывай о уровне знаний, ничего сложнее строк
Заодно может решишь проблему с leng

Добавлено через 2 минуты
Ну здесь много мне неизвестного
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 17:39     Не могу разобраться с отработкой циклов #30
Стандартные контейнеры не знаешь?
Я просто тебе сделал задел для змейки переменной длины. Там чуток только код дополнить.
list и pair можешь заменить на свою реализацию списка и любой структуры, хранящей координаты.
В этой реализации тебе будет проще проверять самопоедание змейки и столкновение с границами.
Я этого писать не стал, чтоб не захламлять код.
Fafle
 Аватар для Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 17:42  [ТС]     Не могу разобраться с отработкой циклов #31
ни контейнеры, ни структуры, я пока до этого еще не дошел
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 17:53     Не могу разобраться с отработкой циклов #32
В общем std::list это просто список
вместо std:air можешь сделать
C++
1
2
3
4
struct Link
{
    int first, second;
};
Суть движения в том, что вынимаешь из списка первый элемент и добавляешь в конец новый элемент, равный сумме последнего и смещения.
Только вот я ошибся и голова змейки находится в конце списка, но это ни на что не влияет.)

Добавлено через 19 секунд
.)))))))) Смайлик это не я нарисовал.))))))))

Добавлено через 2 минуты
Ну и вместо getch нужно использовать функцию асинхронного чтения клавы, чтобы змейка могла нестись дальше и без нажатия клавиш.
Fafle
 Аватар для Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 18:00  [ТС]     Не могу разобраться с отработкой циклов #33
Цитата Сообщение от Deviaphan Посмотреть сообщение
Ну и вместо getch нужно использовать функцию асинхронного чтения клавы, чтобы змейка могла нестись дальше и без нажатия клавиш.
А можно что то подобное у меня в коде реализовать?
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 18:25     Не могу разобраться с отработкой циклов #34
Функция GetAsyncKeyState - но это для Windows.
А у тебя не виндоус, так что не знаю. Может в conio есть аналогичное что-то.

Добавлено через 14 минут
1 - добавить звено
3 - удалить
При движении влево добавляются некорректно, т.к. проверок никаких естессно не делал.
Зато анимация уже есть.)
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
#include <conio.h>
#include <list>
 
#define SIZE1 21
#define SIZE2 60
 
typedef std::pair<int,int> Link;
typedef std::list<Link> Snake;
 
Link operator+ ( Link lhs, const Link & rhs )
{
    lhs.first += rhs.first;
    lhs.second += rhs.second;
    return lhs;
}
 
bool SnakeHere(const Snake & s, int w, int h )
{
    for( Snake::const_iterator ii = s.begin(); ii != s.end(); ++ii )
    {
        if( ii->first == w && ii->second == h )
            return true;
    }
 
    return false;
}
 
void AddLink( Snake & snake, int count )
{
    for( int i = 0; i < count; ++i )
        snake.push_back(snake.back() + Link(1,0));
}
 
void RemoveLink( Snake & snake, int count )
{
    for( int i = 0; i < count; ++i )
        snake.pop_front();
}
 
void Play()
{
    Snake snake;
    const int linkCount = 10;
 
    for( int i = 0; i < linkCount; ++i )
        snake.push_back( Link(i+1,1) );
 
    Link dir(1,0);
 
    while( true )
    {
        system("cls");
        
        for( int h = 0; h < SIZE1; ++h )
        {
            for( int w =0; w < SIZE2; ++w )
            {
                const bool edge = h == 0 || h == (SIZE1-1) || w == 0 || w == (SIZE2-1);
                if( edge )
                    putch( 'W' );
                else  if( SnakeHere( snake, w, h ) )
                    putch( 'O' );
                else
                    putch( ' ' );
            }
            putch( '\n' );
        }
 
        if( kbhit() )
        {
            switch( getch() )
            {
            case 'q':
                return;
            case 'w':
                dir = Link(0,-1);
                break;
            case 'a':
                dir = Link(-1,0);
                break;
            case 'd':
                dir = Link(1,0);
                break;
            case 's':
                dir = Link(0,1);
                break;
            case '1':
                AddLink( snake, 1 );
                break;
            case '3':
                RemoveLink(snake, 1);
                break;
            };
        }
        snake.pop_front();
        snake.push_back( snake.back() + dir );
    };
 
}
 
int main() {
    Play();
    return 0;
}
Fafle
 Аватар для Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 18:29  [ТС]     Не могу разобраться с отработкой циклов #35
Вот уже с яблочком и ростом :)
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
#include <iostream>
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <time.h>
#include <string.h>
#define SIZE1 21
#define SIZE2 60
 
using namespace std;
 
void print(char ar[][60]) {
      srand(time(NULL));
    int i = 1;
    int j = 1;
    int a, leng = 3;
    ar[i][j] = 'X';
    char b='A';
    ar[rand()%21+1][rand()%60+1]=b;
    char *str[100];
    for (int m = 0;m < 100; m++)
        str[m] = new char[100];
    while (1 != 0) {
        for (int g = 0; g < SIZE1; g++)
            puts(ar[g]);
        a = getch();
        switch (a) {
             case 100:
                if ((j + 1) != SIZE2 - 2) {
                    if(ar[i][j + 1]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i][j + 1] = ar[i][j];
                    str[0] = &ar[i][j];
                    j++;
                } else {
                    if(ar[i][j - (SIZE2 - 4)[j]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i][j - (SIZE2 - 4)] = ar[i][j];
                    str[0] = &ar[i][j];
                    j = j - (SIZE2 - 4);
                }
                break;
            case 119:
                if (i + 1 != SIZE1 - 1) {
                    if(ar[i + 1][j]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i + 1][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i++;
                } else {
                    if(ar[i - (SIZE1 - 3)]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i - (SIZE1 - 3)][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i = i - (SIZE1 - 3);
                }
                break;
            case 115:
                if ((i - 1) != 0) {
                    if(ar[i - 1][j]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i - 1][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i--;
                } else {
                    if(ar[i + (SIZE1 - 3)][j]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i + (SIZE1 - 3)][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i += SIZE1 - 3;
                }
                break;
            case 97:
                if ((j - 1) != 0) {
                    if(ar[i][j - 1]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i][j - 1] = ar[i][j];
                    str[0] = &ar[i][j];
                    j--;
                } else {
                    if(ar[i][j + (SIZE2 - 4)]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i][j + (SIZE2 - 4)] = ar[i][j];
                    str[0] = &ar[i][j];
                    j += SIZE2 - 4;
                }
                break;
            case 'q':
                return;
        }
        for (int v = leng + 2; v > 0; v--)
            str[v] = str[v - 1];
        *str[leng + 2] = ' ';
 
        system("cls");
 
    }
}
 
int main() {
    char ar[21][60];
 
    for (int i = 0; i < SIZE1; i++) {
        for (int j = 0; j < SIZE2; j++) {
            if (j == SIZE2 - 1)
                ar[i][j] = '\0';
            else {
                if ((i == 0) || (i == SIZE1 - 1) || (j == 0) || (j == SIZE2 - 2)) {
                    ar[i][j] = 'X';
                } else {
                    ar[i][j] = ' ';
                }
            }
        }
    }
    print(ar);
}


Добавлено через 1 минуту
Я к сожалению глянуть не могу, у мя conio нету
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 18:39     Не могу разобраться с отработкой циклов #36
Т.е. ты всё это чудо пишешь не компилируя и ещё спрашиваешь, почему цикл не правильно работает? о_0
conio.h это из твоего кода.)
Fafle
 Аватар для Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 18:43  [ТС]     Не могу разобраться с отработкой циклов #37
Только вот не знаю как менюшку реализовать с описанием горячих клавиш и и выводом "game over", даже не как, а где, получится ли сбоку?

Добавлено через 1 минуту
Цитата Сообщение от Deviaphan Посмотреть сообщение
Т.е. ты всё это чудо пишешь не компилируя и ещё спрашиваешь, почему цикл не правильно работает? о_0
conio.h это из твоего кода.)
Я свой код переделываю под винду вручную ятоб ты глянуть его мог, и сейчас попробуй запусти, я там подковырял
Мое "чудо" выглядит так :)
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
#include <iostream>
#include <stdio.h>
#include <termios.h>
#include <unistd.h>
#include <string.h>
#include <time.h>
#include <stdlib.h>
#define SIZE1 21
#define SIZE2 60
 
using namespace std;
 
 
int getch() {
    struct termios oldt, newt;
    int ch;
    tcgetattr(STDIN_FILENO, &oldt);
    newt = oldt;
    newt.c_lflag &= ~(ICANON | ECHO);
    tcsetattr(STDIN_FILENO, TCSANOW, &newt);
    ch = getchar();
    tcsetattr(STDIN_FILENO, TCSANOW, &oldt);
    return ch;
}
void print(char ar[][60]) {
    srand(time(NULL));
    int i = 1;
    int j = 1;
    int a, leng = 3;
    ar[i][j] = 'X';
    char b='A';
    ar[rand()%21+1][rand()%60+1]=b;
    char *str[100];
    for (int m = 0;m < 100; m++)
        str[m] = new char[100];
    while (1 != 0) {
        for (int g = 0; g < SIZE1; g++)
            puts(ar[g]);
        a = getch();
        switch (a) {
            case 67:
                if ((j + 1) != SIZE2 - 2) {
                    if(ar[i][j + 1]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i][j + 1] = ar[i][j];
                    str[0] = &ar[i][j];
                    j++;
                } else {
                    if(ar[i][j - (SIZE2 - 4)]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i][j - (SIZE2 - 4)] = ar[i][j];
                    str[0] = &ar[i][j];
                    j = j - (SIZE2 - 4);
                }
                break;
            case 66:
                if (i + 1 != SIZE1 - 1) {
                    if(ar[i + 1][j]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i + 1][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i++;
                } else {
                    if(ar[i - (SIZE1 - 3)][j]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i - (SIZE1 - 3)][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i = i - (SIZE1 - 3);
                }
                break;
            case 65:
                if ((i - 1) != 0) {
                    if(ar[i - 1][j]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i - 1][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i--;
                } else {
                    if(ar[i + (SIZE1 - 3)][j]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i + (SIZE1 - 3)][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i += SIZE1 - 3;
                }
                break;
            case 68:
                if ((j - 1) != 0) {
                    if(ar[i][j - 1]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i][j - 1] = ar[i][j];
                    str[0] = &ar[i][j];
                    j--;
                } else {
                    if(ar[i][j + (SIZE2 - 4)]==b){
                        ar[rand()%10+1][rand()%10+1]=b;
                        leng+=3;
                    }
                    ar[i][j + (SIZE2 - 4)] = ar[i][j];
                    str[0] = &ar[i][j];
                    j += SIZE2 - 4;
                }
                break;
            case 'q':
                return;
        }
        for (int v = leng; v > 0; v--)
            str[v] = str[v - 1];
        *str[leng] = ' ';
 
        cout << "\E[H\E[J";
 
    }
}
 
int main() {
    char ar[21][60];
 
    for (int i = 0; i < SIZE1; i++) {
        for (int j = 0; j < SIZE2; j++) {
            if (j == SIZE2 - 1)
                ar[i][j] = '\0';
            else {
                if ((i == 0) || (i == SIZE1 - 1) || (j == 0) || (j == SIZE2 - 2)) {
                    ar[i][j] = 'X';
                } else {
                    ar[i][j] = ' ';
                }
            }
        }
    }
    print(ar);
}
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 19:18     Не могу разобраться с отработкой циклов #38
Не, там что-то сильно поломалось.)
Ты там getch сам реализовал? Я видел реализацию kbhit где-то. Погугли.)
Fafle
 Аватар для Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
03.04.2011, 11:54  [ТС]     Не могу разобраться с отработкой циклов #39
Вот что есть на данный момент, не реализован разве что случай появление яблока на самой змейке, но трабл в другом, при попытке высвободить память консолька ругается
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
#include <iostream>
#include <stdio.h>
#include <conio.h>
#include <string.h>
#include <time.h>
#include <stdlib.h>
#define SIZE1 21
#define SIZE2 60
using namespace std;
int main();
void win(void){
cout << "\E[H\E[J";
cout<<"You win!!!\nPress A(to play again) of Q(to quit)\n";
char a=getch();
switch(a){
    case 97:
        main();
        break;
    case 'q':
        return;
}
void over(void){
cout << "\E[H\E[J";
cout<<"Game Over!!!\nPress A(to play again) of Q(to quit)\n";
char a=getch();
switch(a){
    case 97:
        main();
        break;
    case 'q':
        return;
}
}
void print(char ar[][60]) {
    srand(time(NULL));
    int i = 1;
    int j = 1;
    int a, leng = 3;
    ar[i][j] = 'X';
    char b='A';
    ar[rand()%19+1][rand()%57+1]=b;
    char *str[100];
    for (int m = 0;m < 100; m++)
        str[m] = new char[100];
    while (1 != 0) {
 if(leng>96)
            win();
        cout<<"To move press: Up Down Left; To quit press Q."<<endl;
        for (int g = 0; g < SIZE1; g++)
            puts(ar[g]);
        a = getch();
        switch (a) {
            case 'd':
                if ((j + 1) != SIZE2 - 2) {
                    if(ar[i][j + 1]==b){
                        ar[rand()%19+1][rand()%57+1]=b;
                        leng+=3;
                    }
                    if(ar[i][j + 1]=='X'){
//                        for(int m=0;m<100;m++)
//                            delete[] str[m];
                        over();
                        return;
                    }
                    ar[i][j + 1] = ar[i][j];
                    str[0] = &ar[i][j];
                    j++;
                } else {
                    if(ar[i][j - (SIZE2 - 4)]==b){
                        ar[rand()%19+1][rand()%57+1]=b;
                        leng+=3;
                    }
                    if(ar[i][j - (SIZE2 - 4)]=='X'){
                        over();
                        return;
                    }
                    ar[i][j - (SIZE2 - 4)] = ar[i][j];
                    str[0] = &ar[i][j];
                    j = j - (SIZE2 - 4);
                }
                break;
            case 's':
                if (i + 1 != SIZE1 - 1) {
                    if(ar[i + 1][j]==b){
                        ar[rand()%19+1][rand()%57+1]=b;
                        leng+=3;
                    }
                    if(ar[i + 1][j]=='X'){
                        over();
                        return;
                    }
                    ar[i + 1][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i++;
                } else {
                    if(ar[i - (SIZE1 - 3)][j]==b){
                        ar[rand()%19+1][rand()%57+1]=b;
                        leng+=3;
                    }
                    if(ar[i - (SIZE1 - 3)][j]=='X'){
                        over();
                        return;
                    }
                    ar[i - (SIZE1 - 3)][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i = i - (SIZE1 - 3);
                }
                break;
            case 'w':
                if ((i - 1) != 0) {
                    if(ar[i - 1][j]==b){
                        ar[rand()%19+1][rand()%57+1]=b;
                        leng+=3;
                    }
                    if(ar[i - 1][j]=='X'){
                        over();
                        return;
                    }
                    ar[i - 1][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i--;
                } else {
                    if(ar[i + (SIZE1 - 3)][j]==b){
                        ar[rand()%19+1][rand()%57+1]=b;
                        leng+=3;
                    }
                    if(ar[i + (SIZE1 - 3)][j]=='X'){
                        over();
                        return;
                    }
                    ar[i + (SIZE1 - 3)][j] = ar[i][j];
                    str[0] = &ar[i][j];
                    i += SIZE1 - 3;
                }
                break;
            case 'a':
                if ((j - 1) != 0) {
                    if(ar[i][j - 1]==b){
                        ar[rand()%19+1][rand()%59+1]=b;
                        leng+=3;
                    }
                    if(ar[i][j - 1]=='X'){
                        over();
                        return;
                    }
                    ar[i][j - 1] = ar[i][j];
                    str[0] = &ar[i][j];
                    j--;
                } else {
                    if(ar[i][j + (SIZE2 - 4)]==b){
                        ar[rand()%19+1][rand()%58+1]=b;
                        leng+=3;
                    }
                    if(ar[i][j + (SIZE2 - 4)]=='X'){
                        over();
                        return;
                    }
                    ar[i][j + (SIZE2 - 4)] = ar[i][j];
                    str[0] = &ar[i][j];
                    j += SIZE2 - 4;
                }
                break;
            case 'q':
                return;
        }
        for (int v = leng; v > 0; v--)
            str[v] = str[v - 1];
        *str[leng] = ' ';
 
        system("cls");
 
    }
}
 
int main() {
    char ar[21][60];
 
    for (int i = 0; i < SIZE1; i++) {
        for (int j = 0; j < SIZE2; j++) {
            if (j == SIZE2 - 1)
                ar[i][j] = '\0';
            else {
                if ((i == 0) || (i == SIZE1 - 1) || (j == 0) || (j == SIZE2 - 2)) {
                    ar[i][j] = 'X';
                } else {
                    ar[i][j] = ' ';
                }
            }
        }
    }
    print(ar);
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.04.2011, 14:17     Не могу разобраться с отработкой циклов
Еще ссылки по теме:

не могу разобраться C++
C++ Не могу разобраться
Не могу разобраться в if C++

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

Или воспользуйтесь поиском по форуму:
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
03.04.2011, 14:17     Не могу разобраться с отработкой циклов #40
Для Str[0] тоже delete вызываешь? Если да, то я тебе уже ответил.
И ты не нарисовал, где и как вызываешь очистку, поэтому я не знаю, на что ругается твоя консолька.)
Yandex
Объявления
03.04.2011, 14:17     Не могу разобраться с отработкой циклов
Ответ Создать тему
Опции темы

Текущее время: 02:07. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru