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

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

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

Кто поможет описать код?пожалуйста - C++

11.04.2013, 20:12. Просмотров 194. Ответов 0
Метки нет (Все метки)

Кто поможет описать код?
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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <conio.h>
 
#define MENTION printf("Enter 'j', 'i', 'l' or 'k' to move the empty cell left, up, right or down correspondingly, or 'q' to exit: \n\n");
 
int** field;
int emptyCell_x, emptyCell_y;
 
//------------------
void init()
{
    int x,y, i,j;
    srand(time(NULL));
    for(i=1; i<=15;)
    {
        x=rand()%4; y=rand()%4;
        if(field[x][y] == 0) field[x][y] = i++;     
    }
 
    for(i=0; i<4; i++) //to find the empty cell
        for(j=0; j<4; j++)
            if(field[j][i] == 0) 
            {
                emptyCell_x=j; emptyCell_y = i; return;
            }
 
}
 
//---------------------
void printField()
{
    int i,j;
    for(i=0; i<4; i++)
    {
        for(j=0; j<4; j++)
            if(field[j][i]) printf("%3d", field[j][i]);
            else printf("  _");
        printf("\n\n");
    }
    printf("\n\n");
}
 
//-----------------------
int notEndYet()
{
    int i,j;
    for(i=0; i<3; i++)
        for(j=0; j<4; j++)
            if(field[j][i] != 4*i+j+1) return 0; //go on play
    if(field[0][3] != 13) return 0;
 
    return 1; //victory!
}
 
//---------------   allows move the emply cell
int move()
{
    char c;
    
    while(1)
    {
        c = getch(); 
        switch(c)
        {
            case 'j':
                if(emptyCell_x==0)
                {
                    printf("Not valid move.\n\n");
                    break;
                }
                else
                {
                    field[emptyCell_x][emptyCell_y] = field[emptyCell_x-1][emptyCell_y];
                    field[emptyCell_x-1][emptyCell_y] = 0;
                    emptyCell_x--;
                    return 1;
                }
            case 'i':
                if(emptyCell_y==0)
                {
                    printf("Not valid move.\n\n");
                    break;
                }
                else
                {
                    field[emptyCell_x][emptyCell_y] = field[emptyCell_x][emptyCell_y-1];
                    field[emptyCell_x][emptyCell_y-1] = 0;
                    emptyCell_y--;
                    return 2;
                }
            case 'l':
                if(emptyCell_x==3)
                {
                    printf("Not valid move.\n\n");
                    break;
                }
                else
                {
                    field[emptyCell_x][emptyCell_y] = field[emptyCell_x+1][emptyCell_y];
                    field[emptyCell_x+1][emptyCell_y] = 0;
                    emptyCell_x++;
                    return 3;
                }
            case 'k':
                if(emptyCell_y==3)
                {
                    printf("Not valid move.\n\n");
                    break;
                }
                else
                {
                    field[emptyCell_x][emptyCell_y] = field[emptyCell_x][emptyCell_y+1];
                    field[emptyCell_x][emptyCell_y+1] = 0;
                    emptyCell_y++;
                    return 4;
                }
            case 'q': exit(1);
            default: MENTION
        }
    }
}
 
//----------------- main function
void main()
{
    field = (int**)calloc(4, sizeof(int*));
    for(int i=0; i<4; i++)
        field[i] = (int*)calloc(4, sizeof(int));
 
    do  init(); while(notEndYet());
    MENTION
    printField();
    
    while(!notEndYet())
    {
        move();
        printField();
    }
 
    printf("\nYou win!\n"); getch();
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.04.2013, 20:12
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Кто поможет описать код?пожалуйста (C++):

Кто поможет вкратце описать код "Определитель матрицы"? - C++
Желательно строки которые обозначены плюсом и всю функцию determ(что в ней происходит)? #include &lt;iostream&gt; #include &lt;cmath&gt; ...

Кто-нибудь может закоментировать код слэшами,пожалуйста? - C++
#include &quot;wot.h&quot; #include &lt;stdio.h&gt; #include &lt;windows.h&gt; #include &lt;iostream&gt; #include &lt;stdlib.h&gt; #include &lt;conio.h&gt; #include...

проверьте пожалуйста еще один код программы, кто может - C++
проверьте пожалуйста еще один код программы(кто может вот условие: программа должна проверить число является ли оно простым или нет? ...

может поможет кто? - C++
тебята я только недавно начал изучать язык С++ по книге Герберта шелтда. Кароче там один момент который я понять не могу а именно: тип...

Даны действительные числа a, b. кто поможет - C++
Даны действительные числа a, b. Получить u = min(a, b-a), y = min(ab, a+b), k = min(u+v2, 3.14).

Кто поможет сделать оконный вид программы? - C++
Код : №1 #include &lt;iostream&gt; #include &lt;iomanip&gt; using namespace std; int main () { const...

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.04.2013, 20:12
Привет! Вот еще темы с ответами:

Кто поможет c C++ (ООП, WinAPI) в определенный день? - C++
Здравствуйте. Кто бы смог помочь с c++ и возможно winapi в определенный день? Пару простых вопросов по ООП. Напишите в лс.

Написать код для игры НИМ. проверьте пожалуйста тот ли это код - C++
#include &lt;string&gt; using namespace std; int compChoose(int markers); int userChoose(int markers); int...

Может кто словами описать алгоритм многопутевого слияния? - C++
Может кто словами описать алгоритм многопутевого слияния? В виде: 1-й шаг: делаем то 2-й шаг: делаем это и т. д. В гугле...

Пожалуйста,кто знает.....массив переменных структур.. - C++
Имеется список,каждая строка которого содержит следующию информацию: 1)вид жилья:государственная квартира,ведомственная квартира или...


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

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

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