Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/9: Рейтинг темы: голосов - 9, средняя оценка - 4.67
2 / 2 / 1
Регистрация: 22.11.2012
Сообщений: 99
1

Объяснить алгоритм игры "Кошки-Мышки"

28.05.2014, 09:54. Показов 1715. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Пишу курсовую работу, и вот не могу понять эти алгоритмы. Если кто не линивый, отзовитесь пожалуйста.
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
 private boolean isCollisian() {
 
        if (distance(catPos, mousePos) <= 2) {
            return true;
        }
 
        return false;
 
    }
 
    private double distance(Point pos1, Point pos2) {
 
        int px = pos1.x - pos2.x;
        int py = pos1.y - pos2.y;
 
        return Math.ceil(Math.sqrt(px * px + py * py));
    }
Java
1
2
3
4
5
6
7
8
 private boolean canMoveTo(int x, int y) {
 
        if (x < 0 || x >= width || y < 0 || y >= height) {
            return false;
        }
 
        return true;
    }
Java
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
private void mouseBot() {
 
        Point newMousePos = mousePos;
        double maxDistance = 0;
 
        Point points[] = {
            new Point(mousePos.x - 1, mousePos.y),
            new Point(mousePos.x + 1, mousePos.y),
            new Point(mousePos.x, mousePos.y - 1),
            new Point(mousePos.x, mousePos.y + 1),
            new Point(mousePos.x - 1, mousePos.y - 1),
            new Point(mousePos.x + 1, mousePos.y - 1),
            new Point(mousePos.x - 1, mousePos.y + 1),
            new Point(mousePos.x + 1, mousePos.y + 1)
        };
 
        if (catRound == true) {
 
            for (Point p : points) {
 
                double dist = distance(catPos, p);
 
                if (canMoveTo(p) && (dist >= maxDistance)) {
 
                    maxDistance = dist;
                    newMousePos = p;
                }
 
            }
 
            removeContent(mousePos.x, mousePos.y);
            mousePos = newMousePos;
            changePosition();
        }
    }
Java
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
private void moveS(int orientation){
 
        if(pause == true) {
            return;
        }
        
        removeContent(catPos.x, catPos.y);
 
        catRound = false;
 
        switch (orientation) {
 
            case UP: {
 
                if (canMoveTo(catPos.x, catPos.y - 1)) {
                    catPos.translate(0, -1);
                    countRound++;
                }
 
            }
            break;
 
            case DOWN: {
 
                if (canMoveTo(catPos.x, catPos.y + 1)) {
                    catPos.translate(0, 1);
                    countRound++;
                }
 
            }
            break;
 
            case LEFT: {
 
                if (canMoveTo(catPos.x - 1, catPos.y)) {
                    catPos.translate(-1, 0);
                    countRound++;
                }
 
            }
            break;
 
            case RIGHT: {
                if (canMoveTo(catPos.x + 1, catPos.y)) {
                    catPos.translate(1, 0);
                    countRound++;
                }
            }
            break;
 
        }
 
        changePosition();
 
        if (gameIsOver()) {
            gameOver();
            return;
        }
 
        if (countRound == 3) {
            catRound = true;
            countRound = 0;
            mouseBot();
        }
 
    }
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
private void randomPosition() {
 
        int x;
        int y;
 
        x = (int) (Math.random() * width);
        y = (int) (Math.random() * height);
 
        catPos = new Point(x, y);
 
        do {
            x = (int) (Math.random() * width);
            y = (int) (Math.random() * height);
 
            mousePos = new Point(x, y);
            
        } while (isCollisian());
 
        changePosition();
    }
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
28.05.2014, 09:54
Ответы с готовыми решениями:

Полторы кошки за полтора часа съедают полтора мышки
Полторы кошки за полтора часа съедают полтора мышки.Сколько мышек съедят n кошек за m часов? ...

Кошки и мышки С++
N серых и M белых мышей сидят по кругу. Кошка ходит по кругу по часовой стрелке и съедает каждую S...

Игра кошки - мышки
Мне надо чтоб было два label кошка и мышка. И мышка должна убегать а кошка догонять. Это типа как...

полторы кошки за полтора часа съедают полторы мышки. Сколько мышек съедят X кошек за Y часов?
ПОМОГИТЕ ПОЖАЛУЙСТА&quot;! Нужно сделать задание во фри паскале! полторы кошки за полтора часа съедают...

1
Супер-модератор
6192 / 2938 / 1300
Регистрация: 04.03.2013
Сообщений: 5,780
Записей в блоге: 1
28.05.2014, 18:57 2
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
//этот метод походу возвращает истину если расстояние от кота до мыши <=2
//и ложь, если больше 
//вызывая второй метод, с координатами кота и мышки
private boolean isCollisian() {
 
        if (distance(catPos, mousePos) <= 2) {
            return true;
        }
 
        return false;
 
    }
 
//этот метод по двум точкам Point, собственно
//координатам кота и мыши высчитывает гипотенузу - кратчайшее растояние
//между ними
private double distance(Point pos1, Point pos2) {
 
        int px = pos1.x - pos2.x;
        int py = pos1.y - pos2.y;
 
        return Math.ceil(Math.sqrt(px * px + py * py));
    }
Добавлено через 3 минуты
Java
1
2
3
4
5
6
7
8
9
10
11
//Если x или y выходит за рамки рабочей области от x от 0 до width
//у от 0 до height то значит выдает ложь. Туда пойти нельзя
//иначе выдает истину, что можно туда пойти
private boolean canMoveTo(int x, int y) {
 
        if (x < 0 || x >= width || y < 0 || y >= height) {
            return false;
        }
 
        return true;
    }
0
28.05.2014, 18:57
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
28.05.2014, 18:57
Помогаю со студенческими работами здесь

Создать алгоритм решения ребуса "барс + рысь = кошки"
Создать алгоритм решения ребуса: барс + рысь = кошки (различные буквы обозначают различные цифры,...

Перемещение мышки в неактивном окне игры
Здравствуйте. В игре нужно программно делать поворот камерой с помощью мышки, делаю это следующим...

Программное движение мышки в окне игры Rust!
Создаю программу, которая будет при нажатии на левую копку мыши программно опускать курсор в низ,...

Бот для игры, эмуляция мышки, анализ цвета \ текста с области экрана
Здравствуйте, простите за беспокойство, но не могу найти толковых статей \ гайдов по написанию...

объяснить алгоритм решения
for i:=1 to 3 do begin x:=b mod 10; b:=b div 10; S:=S+x; Объясните пожалуйста, что здесь...

Объяснить алгоритм Прима
Можете объяснить алгоритм Прима? что это такое: a = 1; b = 1; u = 1; v = 1; n = 1;?? public void...


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

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