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

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

Войти
Регистрация
Восстановить пароль
 
enzo32
0 / 0 / 0
Регистрация: 19.02.2016
Сообщений: 42
#1

Подправьте игру пятнашки - C++

02.04.2016, 23:49. Просмотров 371. Ответов 4
Метки нет (Все метки)

Решил написать игрушку 15-ки
я хочу что бы прога содержала такие функции:
заполнение поля числами в случайном порядке;
поиск позиции нуля;
перестановки элементов(Left, Right, Up, Down);
проверки окончания игры
вот что у меня получилось:
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
#include <iostream>
#include <conio.h>
#include <ctime>
#include <iomanip>
#include <windows.h>
using namespace std;
int nolb1(int mas[][4], int row, int col, int size)       //находим место положения нуля в колоне
{
    for(int i=0; i<size; i++)         
    {
        for(int j=0; j<size; j++)
        {
            if(mas[i][j]==0)
            {
                col=j;
                return col;
            }
        }
    }
}
int nolb2(int mas[][4], int row, int col, int size)         //находим место положения нуля в строке
{
    for(int i=0; i<size; i++)         
    {
        for(int j=0; j<size; j++)
        {
            if(mas[i][j]==0)
            {
                row=i;
                return row;
            }
        }
    }
}
 
int test(int mas[][4], int arrow[][4], int size, int m)        //делаем проверку, не собрана ли у нас пятнашки
{
    for(int i=0, counter=0, k=0; i<size; i++,counter++)         
    {
        for(int j=0; j<size; j++)
        {
 
            if(mas[i][j]!=arrow[i][j])
            {
                return 0;
            }
            if(counter==15)
            {
                cout<<"Pyatnashki sobrani"<<endl;
                return m;
            }
        }
    }
}
 
void watch(int mas[][4],int size)                    // посмотрели на пятнашки
{
        for(int i=0; i<size; i++)               
    {
        for(int j=0; j<size; j++)
        {
            cout<<setw(3)<<mas[i][j];
        }
        cout<<endl<<endl;
    }
    cout<<endl;
}
 
int main()
{
    srand((unsigned)time(NULL));
    SetConsoleOutputCP(1251); 
    SetConsoleCP(1251);
    int knopka=0, m=0;
    const int size=4;
    int mas[size][size]={0};
    int arrow[size][size]={0};
    int row=0, col=0, nomber=15;
    while (nomber>0)                       // генерируем случаую пятнашку
    {
        row=rand()%4;    
        col=rand()%4;    
        if(mas[row][col]==0)  
        {
            mas[row][col]=nomber;  
            nomber--;     
        }
    }
 
    watch(mas,size);   //смотрим первый раз на пятнашки
     
 
    for(int i=0, t=1; i<size; i++)              // генерируем собраные пятнашки, для проверки
    {
        for(int j=0; j<size; j++,t++)
        {
            arrow[i][j]+=t;
            arrow[3][3]=0;
            cout<<setw(3)<<arrow[i][j];
        }
        cout<<endl<<endl;
    }
    cout<<endl;
 
    test(mas,arrow,size,m);       // проверяем не совпяли ли пятнашки
    
    nolb1(mas,row,col,size);      //елси не совпали ищем место положение нуля в колонке
    nolb2(mas,row,col,size);      // место положение нуля в строке 
 
    cout<<"1-вверх, 2-вниз, 3-влево, 4-вправо"<<endl;
    for(m=0; m==0; )                                          // упровляем пятнашками
    {
        cin>>knopka;
        if(knopka==1)
        {
            if(row==0)
            {
                break;
            }
            else
            {
                int tmp=mas[row][col];
                mas[row][col]=mas[row+1][col];
                mas[row+1][col]=tmp;
                row++;
            }
            watch(mas,size);
            test(mas,arrow,size,m); 
        }
 
        if(knopka==2)
        {
            if(row==3)
            {
                break;
            }
            else
            {
                int tmp=mas[row][col];
                mas[row][col]=mas[row-1][col];
                mas[row-1][col]=tmp;
                row--;
            }
            watch(mas,size);
            test(mas,arrow,size,m); 
        }
        if(knopka==3)
        {
            if(col==0)
            {
                break;
            }
            else
            {
                int tmp=mas[row][col];
                mas[row][col]=mas[row][col-1];
                mas[row][col-1]=tmp;
                col--;
            }
            watch(mas,size);
            test(mas,arrow,size,m); 
        }
        if(knopka==4)
        {
            if(col==3)
            {
                break;
            }
            else
            {
                int tmp=mas[row][col];
                mas[row][col]=mas[row][col+1];
                mas[row][col+1]=tmp;
                col++;
            }
            watch(mas,size);
            test(mas,arrow,size,m); 
        }
    }
}
но честно, мне что то она не нравится, что нужно исправить, на ваш взгляд и как если что)))
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.04.2016, 23:49
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Подправьте игру пятнашки (C++):

Написать игру «Пятнашки» - C++
Кто знает, как на С++ написать игру «Пятнашки». Программа должна содержать следующие функции: заполнение поля числами в случайном...

Подправьте код - C++
Постоянно ругается на choise, где бы я его не объявлял. Если можно, выложите что вы исправили, и объясните что я сделал нет так. ...

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

Подправьте немного... - C++
Суть задачи: найти сумму ряда с точностью 0.001 общий член n!/3^n^n вот написал какой то бред #include &quot;stdafx.h&quot; #include...

Массивы! Подправьте прогу! - C++
Подскажите ошибки! Прога должна: 1. Превращать в массив введенную строку символов и выводить массив на экран. 2. Из массива...

Подправьте мой код) - C++
Нужно вывести только буквы без символов input \\\aBaBba\\\ output AbBbBA #include &lt;iostream&gt; #include &lt;cstring&gt; ...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
marat_miaki
107 / 96 / 36
Регистрация: 08.04.2013
Сообщений: 346
03.04.2016, 08:23 #2
Для проверки победы хватит и самого массива, чем сравнивать 2
Функция проверки двумерного массива C++

Добавлено через 5 минут
Может алгоритм перемещения отсюда поймаешь, чем искать всегда где ноль лежит
Пятнашки почти работают правильно
1
Serg_o_Grey
76 / 76 / 27
Регистрация: 29.03.2016
Сообщений: 347
03.04.2016, 08:33 #3
1) желательно использовать функцию очистки консольного окна
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <iostream>
 
using namespace std;
 
int main()
{
    string str;
    while(true)
    {
        system("cls");
        cin >> str;
        cout << str;
    }
    cin.get();
    return 0;
}
Добавлено через 22 секунды
пример ее использования
1
marat_miaki
107 / 96 / 36
Регистрация: 08.04.2013
Сообщений: 346
03.04.2016, 08:38 #4
Вот вариант на консоле, вроде бы без проверки на победу
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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <windows.h>
 
#define SIZE  4
#define NUMBS SIZE*SIZE
#define UP    0
#define DOWN  1
#define LEFT  2
#define RIGHT 3
 
int board[SIZE][SIZE];
 
void FillBoard   ( void );
int  HaveSolution( void );
int  EndOfGame   ( void );
void PrintBoard  ( void );    
void Move        ( int  );
 
 
int main( void )
{
    HANDLE cInput = GetStdHandle(STD_INPUT_HANDLE);
    DWORD dr;
    INPUT_RECORD  rec;
    //init
    system("title 15 P U ZZ L E");
    FillBoard();
    PrintBoard();
    //
    while( !EndOfGame() )
    {
        
        //Sleep(50);
        ReadConsoleInput(cInput, &rec, sizeof(INPUT_RECORD), &dr);
        FlushConsoleInputBuffer(cInput);
        if(rec.EventType == KEY_EVENT && rec.Event.KeyEvent.bKeyDown)
        {
            switch(rec.Event.KeyEvent.wVirtualKeyCode) 
            {
            case VK_LEFT:
                Move(LEFT);
                break;
            case VK_RIGHT:
                Move(RIGHT);
                break;
            case VK_UP:
                Move(UP);
                break;
            case VK_DOWN:
                Move(DOWN);
                break;
            }
            PrintBoard();
        }
    }
    return 0;
}
 
void FillBoard( void )
{
    do
    {
        srand( time( NULL ));
        int numbers[NUMBS] = {0};
        int i;
        int nextNum;
        for(i = 0; i < NUMBS-1; i++)
            while(1)
            {
                nextNum = rand()%(NUMBS-1)+1;
                if(numbers[nextNum] == 0)
                {
                    numbers[nextNum] = 1;
                    board[ i/SIZE ][ i%SIZE ] = nextNum;
                    break;
                }
            }
    } while( !HaveSolution() );
}
 
int HaveSolution( void )
{
    int i, j;
    int inv = 0;
    for(i = 0; i < NUMBS; i++)
    {
        if(board[ i/SIZE ][ i%SIZE ] == 0)
            inv += i+1;
        for(j = 0; j < i; j++)
            if(board[ j/SIZE ][ j%SIZE ] > board[ i/SIZE ][ i%SIZE ])
                inv++;
    }
    return (inv%2 ? 0 : 1);
}
 
int EndOfGame( void )
{
    int i;
    for(i = 0; i < NUMBS-1; i++)
        if(board[ i/SIZE ][ i%SIZE ] != i+1)
            return 0;
    return 1;
}
 
void PrintBoard( void )
{
   // system("cls");
   // system("color 0F");
    HANDLE hCon = GetStdHandle(STD_OUTPUT_HANDLE);//Äåñêðèïòîð óñòðîéñòâГ* Г±ГІГ*Г*Г¤Г*ðòГ*îãî âûâîäГ*. Г‚Г*Г*Г·Г*ëå, ГЅГІГ® - äåñêðèïòîð Г*ГЄГІГЁГўГ*îãî ГЅГЄГ°Г*Г*Г*îãî ГЎГіГґГҐГ°Г* ГЄГ®Г*ñîëè
    COORD cPos;
    unsigned char BL = 219;
    SetConsoleTextAttribute(hCon, BACKGROUND_RED | BACKGROUND_RED | BACKGROUND_INTENSITY);//ÖÂÅÒ ÂÅÐÕÍÅÉ ÏÎËÎÑÊÈ
    printf("PYATNASHKI 15");
    SetConsoleTextAttribute(hCon, FOREGROUND_BLUE | FOREGROUND_RED | FOREGROUND_RED| BACKGROUND_BLUE);//ÖÈÔÐÛ Г€ ÖÂÅÒ ÎÁÎËÎ×ÊÈ
    int i, j;
    for(i = 0; i < SIZE; i++)
    {
        for(j = 0; j < SIZE; j++)
        {
            cPos.X = j*3;
            cPos.Y = i*2+1;
            //maybe at five or maybe at six
 
            SetConsoleCursorPosition(hCon, cPos);//ÓñòГ*Г*Г*âëèâГ*ГҐГІ ïîçèöèþ êóðñîðГ* Гў Г§Г*Г¤Г*Г*Г*îì ГЅГЄГ°Г*Г*Г*îì áóôåðå ГЄГ®Г*ñîëè.
            printf("%c%c%c%c", BL, BL, BL, BL);
            cPos.Y = i*2+2;
            cPos.X = j*3;
            SetConsoleCursorPosition(hCon, cPos);
            if(board[i][j])
                printf("%c%2i%c", BL, board[i][j], BL);
            else
                printf("%c  %c", BL, BL);
            cPos.Y = i*2+3;
            cPos.X = j*3;
            SetConsoleCursorPosition(hCon, cPos);
            printf("%c%c%c%c", BL, BL, BL, BL);
        }
    }
    SetConsoleTextAttribute(hCon, BACKGROUND_RED| BACKGROUND_RED| BACKGROUND_INTENSITY);
   printf("\nD  A  S  H  A\n");
}
 
void Move( int direction )
{
    int dy[] = {1,-1, 0, 0};
    int dx[] = {0, 0, 1,-1};
    int i, j;
    for(i = 0; i < SIZE; i++)
        for(j = 0; j < SIZE; j++)
            if(board[i][j] == 0)
            {
                int newy = i + dy[direction];
                int newx = j + dx[direction];
                if( newy >= 0 && newy < SIZE &&
                    newx >= 0 && newx < SIZE)
                    {
                        board[i][j] = board[newy][newx];
                        board[newy][newx] = 0;
                    }
                return;
            }
}
1
Serg_o_Grey
76 / 76 / 27
Регистрация: 29.03.2016
Сообщений: 347
03.04.2016, 09:46 #5
обрагородьте перехватом клавиш со стрелками:

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
#include <iostream>
#include <conio.h>
 
using namespace std;
 
int main()
{
    int x;
    while(x = getch())
    {
        switch(x)
        {
            case 75: cout << "Влево" << endl;
            break;
            case 77: cout << "Вправо" << endl;
            break;
            case 72: cout << "Вверх" << endl;
            break;
            case 80: cout << "Вниз" << endl;
            break;
        }
    }
    setlocale(LC_ALL, "Russian");
}
Добавлено через 1 минуту
подробнее здесь смотрите:
Коды клавиш и обработка событий клавиатуры в консоли
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.04.2016, 09:46
Привет! Вот еще темы с ответами:

Подправьте прогу( сортировка массивов) - C++
Подправьте прогу пожалуйста, проверьте на ошибки и добавьте нужные cout, cin, чтоб выводило результаты на консоль.(Задание: Дан массив...

Подправьте код кому не сложно - C++
#include &quot;iostream&quot; #include &lt;stdio.h&gt; using namespace std; class Rastenie { /*îïèñàíèå ýëåìåíòîâ êëàññà Ðàñòåíèé*/ ...

Подправьте рандом в двумерном массиве (матрице) - C++
#include&lt;iostream&gt; #include &lt;Windows.h&gt; #include &lt;time.h&gt; #include&lt;iomanip&gt; using namespace std; void main() { ...

Подправьте программу. динамическая матрица, определение максимального элемента - C++
Пусть пользователь вводит динамическую матрицу размером NxN. Определить максимальный элемент. Нужно чтобы пользователь полностью сам...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
03.04.2016, 09:46
Ответ Создать тему
Опции темы

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