Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 15, средняя оценка - 4.73
Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
#1

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

02.04.2011, 13:32. Просмотров 2039. Ответов 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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.04.2011, 13:32
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Не могу разобраться с отработкой циклов (C++):

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

не могу разобраться.. - C++
Вывести на экран все натуральные числа из диапазона от A до B, в записи которых цифра 7 встречается ровно N раз. При отсутствии чисел с...

Не могу разобраться с С++ - C++
Всем Привет, так я кодеру в Делфи. Не давно нашел что мне нужно но оy написан на С. Вот и начался у меня проблемы с кодами. Вот часть...

Не могу разобраться с ошибкой - C++
Всю голову переломал почему он ругается на cout в 11 строке. Подскажите пожалуйста. #include &lt;iostream.h&gt; #include &lt;conio.h&gt; #include...

Не могу разобраться с программой - C++
Я поступил в Колледж Вычислительной Техники и у нас началось программированиею Сказали поставить Visual C++ 2010, я поставил и теперь не...

Не могу разобраться с задачей - C++
Найдите последовательность, содержащую N последовательных натуральных чисел (N=2k+1), таких, что сумма квадратов первых k+1 чисел равна...

49
Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 17:42  [ТС] #31
ни контейнеры, ни структуры, я пока до этого еще не дошел
0
Deviaphan
Делаю внезапно и красиво
Эксперт С++
1306 / 1221 / 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 нужно использовать функцию асинхронного чтения клавы, чтобы змейка могла нестись дальше и без нажатия клавиш.
0
Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
02.04.2011, 18:00  [ТС] #33
Цитата Сообщение от Deviaphan Посмотреть сообщение
Ну и вместо getch нужно использовать функцию асинхронного чтения клавы, чтобы змейка могла нестись дальше и без нажатия клавиш.
А можно что то подобное у меня в коде реализовать?
0
Deviaphan
Делаю внезапно и красиво
Эксперт С++
1306 / 1221 / 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;
}
0
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 нету
0
Deviaphan
Делаю внезапно и красиво
Эксперт С++
1306 / 1221 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 18:39 #36
Т.е. ты всё это чудо пишешь не компилируя и ещё спрашиваешь, почему цикл не правильно работает? о_0
conio.h это из твоего кода.)
0
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);
}
0
Deviaphan
Делаю внезапно и красиво
Эксперт С++
1306 / 1221 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
02.04.2011, 19:18 #38
Не, там что-то сильно поломалось.)
Ты там getch сам реализовал? Я видел реализацию kbhit где-то. Погугли.)
0
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);
}
0
Deviaphan
Делаю внезапно и красиво
Эксперт С++
1306 / 1221 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
03.04.2011, 14:17 #40
Для Str[0] тоже delete вызываешь? Если да, то я тебе уже ответил.
И ты не нарисовал, где и как вызываешь очистку, поэтому я не знаю, на что ругается твоя консолька.)
0
Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
03.04.2011, 14:50  [ТС] #41
Цитата Сообщение от Deviaphan Посмотреть сообщение
Для Str[0] тоже delete вызываешь? Если да, то я тебе уже ответил.
И ты не нарисовал, где и как вызываешь очистку, поэтому я не знаю, на что ругается твоя консолька.)
Хм, мысль не уловил
Мне получается в строке 60 нужно написать
C++
1
2
3
 for(int m=1;m<100;m++)
                          delete[] str[m];
                         delete[] str;
И почему не с нуля? Или я что то не так понял? Если делаю так, то over не вызывается почему то
0
Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
03.04.2011, 14:58  [ТС] #42
0
Миниатюры
Не могу разобраться с отработкой циклов  
Deviaphan
Делаю внезапно и красиво
Эксперт С++
1306 / 1221 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
03.04.2011, 15:19 #43
Цитата Сообщение от Fafle Посмотреть сообщение
for(int m=1;m<100;m++)
о_0
У тебя str[20], т.е создаёшь 20 и удаляешь 100 объектов.

Цитата Сообщение от Fafle Посмотреть сообщение
delete[] str;
о_0
str[20] не требует вызова delete[] str
Правильно консолька ругается.)
0
Fafle
34 / 34 / 4
Регистрация: 19.03.2010
Сообщений: 136
03.04.2011, 17:04  [ТС] #44
не не не, там я позже выкладывал последний вариант.
0
Deviaphan
Делаю внезапно и красиво
Эксперт С++
1306 / 1221 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
03.04.2011, 18:12 #45
Ага, забыл.) Но str всё равно удалять не нужно.
1
03.04.2011, 18:12
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.04.2011, 18:12
Привет! Вот еще темы с ответами:

Не могу разобраться с кодом - C++
Суть состоит в том чтобы составить программу, выводящую на экран расписание экзаменов и зачетов (предмет,вид...

не могу разобраться рекурсией) - C++
Напишите программу, которая запрашивает число и показатель степени. Напишите рекурсивную функцию, которая возводит число в степень путем...

Не могу разобраться с ошибкой - C++
Программа ханойские башни, нужно что бы выводил графически. Но пишет вот такую ошибку Ошибка 1 error C1083: Не удается открыть файл...

Не могу разобраться с программой в С++ - C++
Написала программку на С++, он ее запускает и как я понимаю выполняет, но вот результатов я не вижу( И вот что мне выдает сама программа: ...


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

Или воспользуйтесь поиском по форуму:
45
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.