Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.63/16: Рейтинг темы: голосов - 16, средняя оценка - 4.63
 Аватар для Fafle
34 / 34 / 9
Регистрация: 19.03.2010
Сообщений: 136

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

02.04.2011, 13:32. Показов 3563. Ответов 49
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть код:
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 дня овыряюсь не могу ошибку найти, заранее спасибо.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
02.04.2011, 13:32
Ответы с готовыми решениями:

Не могу разобраться с отработкой рекурсивной функции
Доброго времени суток. Имеется функция находящая в первом массиве количество повторения второго массива: #include &lt;iostream&gt; ...

Организация циклов, не могу разобраться
Используя операторы циклов, организовать необходимый поиск и вычисления. Тип результата определяется из контекста задачи. Дано...

Задали работу, не могу разобраться. Используется делфи 10, не могу разобраться, как это сделать
В одномерном массиве, состоящем из n вещественных элементов, вычислить: минимальный элемент массива и сумму элементов массива,...

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

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

Не по теме:

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

0
 Аватар для Fafle
34 / 34 / 9
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 16:10  [ТС]
ВОТ
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 будет изменяться и указывает длину змеи
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 16:13

Не по теме:

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


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


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

Не по теме:


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



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

Не по теме:

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

0
02.04.2011, 16:22

Не по теме:

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

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

При любом leng у меня только рамка и Х в левом верхнем углу.
0
 Аватар для Fafle
34 / 34 / 9
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 16:32  [ТС]
Замени 65 66 67 68 на 119 115 100 97 и пользоваться w s d a для управления, у меня просто линь и ASCII таблица другая
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 17:33
Ага, заработало.
НАписал бы 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 секунд
И никаких проверок естессно не делаю.)
0
 Аватар для Fafle
34 / 34 / 9
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 17:36  [ТС]
Ну по другому мне тоже будет интересно посмотреть, н оне забывай о уровне знаний, ничего сложнее строк
Заодно может решишь проблему с leng

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

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

Добавлено через 2 минуты
Ну и вместо getch нужно использовать функцию асинхронного чтения клавы, чтобы змейка могла нестись дальше и без нажатия клавиш.
0
 Аватар для Fafle
34 / 34 / 9
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 18:00  [ТС]
Цитата Сообщение от Deviaphan Посмотреть сообщение
Ну и вместо getch нужно использовать функцию асинхронного чтения клавы, чтобы змейка могла нестись дальше и без нажатия клавиш.
А можно что то подобное у меня в коде реализовать?
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 18:25
Функция 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;
}
0
 Аватар для Fafle
34 / 34 / 9
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 18:29  [ТС]
Вот уже с яблочком и ростом :)
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 нету
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 18:39
Т.е. ты всё это чудо пишешь не компилируя и ещё спрашиваешь, почему цикл не правильно работает? о_0
conio.h это из твоего кода.)
0
 Аватар для Fafle
34 / 34 / 9
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 18:43  [ТС]
Только вот не знаю как менюшку реализовать с описанием горячих клавиш и и выводом "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);
}
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 19:18
Не, там что-то сильно поломалось.)
Ты там getch сам реализовал? Я видел реализацию kbhit где-то. Погугли.)
0
 Аватар для Fafle
34 / 34 / 9
Регистрация: 19.03.2010
Сообщений: 136
03.04.2011, 11:54  [ТС]
Вот что есть на данный момент, не реализован разве что случай появление яблока на самой змейке, но трабл в другом, при попытке высвободить память консолька ругается
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);
}
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
03.04.2011, 14:17
Для Str[0] тоже delete вызываешь? Если да, то я тебе уже ответил.
И ты не нарисовал, где и как вызываешь очистку, поэтому я не знаю, на что ругается твоя консолька.)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.04.2011, 14:17
Помогаю со студенческими работами здесь

Не могу разобраться разобраться с кодом меню
Добрый день. Я понимаю, что тут все, наверное, элементарно. Но я только начала изучение js и пока для меня все страшно и сложно. Проблема...

Редирект с отработкой кода
У меня на странице выполняется код, если переменные существуют - выполняется вывод данных, если не существуют - надо сделать переадресацию...

Проблемма с отработкой ShellExecute
Привет всем. Есть такая проблемма. Я выбираю при помощи OpenDialog файл. Потом по ходу программы, мне нужно запустить этот файл. Я...

Приветствую, не могу разобраться с кодом программы и не могу сделать .obj файл
.model tiny; нужно будет получить исполняемый файл формата СОМ .code org 100h start: mov ax, 3 int 10h ; устанавливаем...

Не могу написать комментарии для функции поиска, не могу разобраться...
void __fastcall TForm1::FindDialog1Find(TObject *Sender) { int found, start, end; // Èíèöèàëèçàöèÿ ïåðåìåííûõ start =...


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

Или воспользуйтесь поиском по форуму:
40
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru