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

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

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

Лабиринт с телепортами на C++ - C++

15.06.2012, 19:21. Просмотров 928. Ответов 2
Метки нет (Все метки)

Пишу простенькую игру - лабиринт с телепортами. Игрок передвигается по лабиринту, входит в один телепорт - выходит из другого. Нужно дойти до выхода. Карта лабиринта считывается из текстового файла.
Сделал движение, но не могу сделать сами телепорты... Преподаватель посоветовал следующее:
Через структуру задаются координаты телепортов, выглядит это так:
# x y tel->
0 12 2 4
1 13 24 3
2 11 3 2
3 12 32 1
4 30 9 1
где x и y координаты телепорта, а tel - номер телепорта в который ведет данный.
решеткой обозначается строка с данными телепортов - т.е. эти номера нигде не прописываются, мы пользуемся ими с помощью массива..
сами телепорты обозначаются цифрами
Вот код программы:

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
#include <dos.h>
#include <stdio.h>
#include <conio.h>
#include <string.h>
#include <iostream.h>
//#include "console.h"
 
#define MR 20
#define MC 60
 
#define PLAYER 'P'
 
enum { KCR=13, KESC=27, KUP=72, KLFT=75, KRT=77, KDN=80 };
 
 
char a[MR][MC],b[MR][MC],fname[13]="map.txt";
FILE *f1,*f2;
int k,nr,nc;
 
typedef struct{
    int x,y,tel,k;
    char name;
} tlink;
tlink z[50];
 
 
void fcolor(char s, char b){
    textcolor(s);
    textbackground(b);
}
 
void select(char z){
        int i,j;
        gotoxy(1,1);
    for(i=0; i<nr; i++){ // reading matrix
        for (j=0; j<nc; j++) {
        if (a[i][j]=='x') {
            fcolor(3,12);
            cprintf(" ");
        }
        else if (a[i][j]==z) {
            fcolor(1,14);
            cprintf("%c", a[i][j]);
        }
        else if (a[i][j]>='P' && a[i][j]<='O') {
            fcolor(1,7);
            cprintf("%c", a[i][j]);
        }
        else {
            fcolor(1,2);
            cprintf("%c", a[i][j]);
        }
            }//-for j
            cprintf("\r\n");
    }//-for i
}//-select
 
void draw(){
    int i,j;
    for(i=0; i<nr; i++){
        for(j=0; j<nc; j++){
            gotoxy(j+1,i+1);
            cprintf("%c", a[i][j]);
        }
    }
}
 
typedef struct {
int x,y,tel;
}
tt[10];
 
 
 
 
int main(){
    fcolor(7,0);
    int i,j,x,y,c;
    char s[101],dir[8],sym;
    printf("”*©« Є*авл: ");
    scanf("%s",fname);
    f1=fopen(fname,"rt");
    if (!f1) printf("FILE not open!!!\n");
    fflush(f1);
    k=fscanf(f1,"%i%i", &nr, &nc);
    fgets(s,100,f1); // Line feed
    if (k<2) {
        printf("ERROR input format: Field's size not found!\n");
        return 1;
    }
    if (nr>MR){
        printf("ERROR input data: Count of rows too large\n");
        return 1;
    }
    if (nc>MC){
        printf("ERROR input data: Count of columns too large\n");
        return 1;
    }
    clrscr();
    for(i=0; i<nr; i++){ // reading matrix
        fgets(s,100,f1);
        for (j=0; j<strlen(s)-1; j++) {  //  j < nc
            if (s[j]==PLAYER) { x=j+1; y=i+1; a[i][j]=' '; }
            else {  a[i][j]=s[j]; }
        }
    }//-for i
 
    int tt=0;
    do{
        fgets(s, 100, f1);
        if feof(f1) break;
        i=sscanf(s,"%i%i%i", &z[tt].x, &z[tt].y, &z[tt].tel);
 
 
    } while(tt<10);
 
 
 
    fclose(f1);
 
    draw();
    gotoxy(x,y); cprintf("P");
    gotoxy(1,23);
 
    for (;;){ //--- Basic Cycle
        char z=getch();     if (!z) z=getch();
 
        switch (z){
            case KESC:  return 0;
            case KLFT: // Key LEFT
                if (a[y-1][x-2]=='.'){
                    gotoxy(x,y); cprintf("%c",a[y-1][x-1]);
                x--;
                    gotoxy(x,y); cprintf("%c",PLAYER);
                }
 
 
                break;
            case KRT: // Key RIGHT
                if (a[y-1][x]=='.'){
                    gotoxy(x,y); cprintf(".");
                    x++;
                    gotoxy(x,y); cprintf("%c",PLAYER);
                }
 
                break;
            case KUP:  // gotoxy(1,20); cprintf("Up",0x4E);break;
                if (a[y-2][x-1]=='.'){
                    gotoxy(x,y); cprintf(".");
                    y--;
                    gotoxy(x,y); cprintf("%c",PLAYER);
                }
                break;
 
            case KDN:
                if (a[y][x-1]=='.'){
                    gotoxy(x,y); cprintf(".");
                    y++;
                    gotoxy(x,y); cprintf("%c",PLAYER);
                }
 
                break;
            default: ;
        }//-switch    z
        gotoxy(1,23);
    }//-basic cycle
//   system("pause");
//   getch();
}
Осталось совсем немного, помогите пожалуйста доделать игру пишу в Turbo C++
0
Вложения
Тип файла: txt map.txt (1.5 Кб, 19 просмотров)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.06.2012, 19:21
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Лабиринт с телепортами на C++ (C++):

Лабиринт C++ - C++
я написал код лабиринта на c++, с помощью чего можно найти кратчайший путь выхода из лабиринта? #include &lt;iostream&gt; #include...

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

Лабиринт - C++
Всем привет. Подскажите, вот делаю игру (понятно какую) но проблема. Вот код #include &quot;stdafx.h&quot; #include &lt;iostream&gt; using namespace...

лабиринт - C++
Коридорами лабиринта разрешается двигаться только в направлениях, указанных стрелками. Человек вошел в комнату A и, выбирая случайным...

Лабиринт - C++
#include &lt;iostream&gt; #include &lt;fstream&gt; #include &lt;conio.h&gt; #include &lt;time.h&gt; #include &lt;cmath&gt; #include &lt;stdio.h&gt; using...

Лабиринт с++ - C++
Есть код. только мне не понятен алгоритм который работает в bool PathExists(Labyrinth&amp; lab, int y1, int x1, int y2, int x2) { и...

2
OstapBender
583 / 522 / 35
Регистрация: 22.03.2011
Сообщений: 1,585
15.06.2012, 19:24 #2
Цитата Сообщение от DreamFAW Посмотреть сообщение
tel - номер телепорта в который ведет данный.
зачем номер? почему просто не сделать 2 переменные - новые x и y?
0
DreamFAW
0 / 0 / 0
Регистрация: 15.06.2012
Сообщений: 4
15.06.2012, 19:30  [ТС] #3
OstapBender, я также хотел сделать, но преподавателю почему-то не понравилось...
Если использовать номер строки (tel) можно сделать следующее:
k = tt[0].tel // номер строки в который ведет телепортер в первой строке
obj.x = tt[k].x // координата x из строки с номером k
Наверное это как-то сопоставить надо было. И вот тут я уже путаюсь и перестаю что-либо понимать...
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.06.2012, 19:30
Привет! Вот еще темы с ответами:

Лабиринт - C++
Вообщем у меня 2 проблемы: 1) Либирнт генерирует 2 раза 2) '8' ходит как хочит Поправте плз код #include &lt;iostream&gt; #include...

Лабиринт - C++
Помогите, пожалуйста, нарисовать лабиринт на всю консоль, чтобы смайлик двигался по лабиринту (лабиринт в виде двумерного массива)

Лабиринт - C++
Народ помогите! есть задание: Лабиринт представляет собой квадрат, состоящий из NxN сегментов. Каждый из сегментов может быть либо...

Лабиринт - C++
Помогите пожалуйста: Создать игру «Лабиринт». Игра состоит из 2 уровней (лабиринтов), отличающихся по сложности. Лабиринты появляются...


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

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

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