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

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

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

Author24 — интернет-сервис помощи студентам
Есть код:
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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
02.04.2011, 13:32
Ответы с готовыми решениями:

Не могу разобраться с отработкой рекурсивной функции
Доброго времени суток. Имеется функция находящая в первом массиве количество повторения второго...

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

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

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

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

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

Не по теме:

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

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

Не по теме:

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


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


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

Не по теме:


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



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

Не по теме:

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

0
Nameless One
02.04.2011, 16:22
  #25

Не по теме:

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

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

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

Добавлено через 2 минуты
Ну здесь много мне неизвестного
0
Делаю внезапно и красиво
Эксперт С++
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 17:39 30
Стандартные контейнеры не знаешь?
Я просто тебе сделал задел для змейки переменной длины. Там чуток только код дополнить.
list и pair можешь заменить на свою реализацию списка и любой структуры, хранящей координаты.
В этой реализации тебе будет проще проверять самопоедание змейки и столкновение с границами.
Я этого писать не стал, чтоб не захламлять код.
1
34 / 34 / 9
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 17:42  [ТС] 31
ни контейнеры, ни структуры, я пока до этого еще не дошел
0
Делаю внезапно и красиво
Эксперт С++
1313 / 1228 / 72
Регистрация: 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 нужно использовать функцию асинхронного чтения клавы, чтобы змейка могла нестись дальше и без нажатия клавиш.
0
34 / 34 / 9
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 18:00  [ТС] 33
Цитата Сообщение от Deviaphan Посмотреть сообщение
Ну и вместо getch нужно использовать функцию асинхронного чтения клавы, чтобы змейка могла нестись дальше и без нажатия клавиш.
А можно что то подобное у меня в коде реализовать?
0
Делаю внезапно и красиво
Эксперт С++
1313 / 1228 / 72
Регистрация: 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;
}
0
34 / 34 / 9
Регистрация: 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 нету
0
Делаю внезапно и красиво
Эксперт С++
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 18:39 36
Т.е. ты всё это чудо пишешь не компилируя и ещё спрашиваешь, почему цикл не правильно работает? о_0
conio.h это из твоего кода.)
0
34 / 34 / 9
Регистрация: 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);
}
0
Делаю внезапно и красиво
Эксперт С++
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 19:18 38
Не, там что-то сильно поломалось.)
Ты там getch сам реализовал? Я видел реализацию kbhit где-то. Погугли.)
0
34 / 34 / 9
Регистрация: 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);
}
0
Делаю внезапно и красиво
Эксперт С++
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
03.04.2011, 14:17 40
Для Str[0] тоже delete вызываешь? Если да, то я тебе уже ответил.
И ты не нарисовал, где и как вызываешь очистку, поэтому я не знаю, на что ругается твоя консолька.)
0
03.04.2011, 14:17
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
03.04.2011, 14:17
Помогаю со студенческими работами здесь

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

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

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

Не могу написать комментарии для функции поиска, не могу разобраться...
void __fastcall TForm1::FindDialog1Find(TObject *Sender) { int found, start, end; //...


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

Или воспользуйтесь поиском по форуму:
40
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru