贪吃蛇(五)蛇撞墙

2023-12-22 21:52
文章标签 贪吃蛇 撞墙

本文主要是介绍贪吃蛇(五)蛇撞墙,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上节我们实现了蛇身向右移动的功能,原理就是增加一个节点,删除一个节点。
本节我们处理蛇撞墙重置的功能

实现原理

在移动函数中检查蛇头(链表尾节点)是否达到墙边的坐标,这里有四种撞墙的情况:

  1. 上墙(当行为0的时候)
  2. 下墙(当行为20的时候)
  3. 左墙(当列为0的时候)
  4. 右墙(当列为20的时候。注意我设置的是19,根据实际修改)
#include"curses.h"
#include "stdlib.h"
struct SnakeNode
{int row;int col;struct SnakeNode* next; 
};struct SnakeNode* head = NULL;
struct SnakeNode* tail = NULL;void addNode();
void mapinit();
void snakeinit()
{// free struct SnakeNode* p;while(head != NULL){p = head;head = head->next;free(p);}head = (struct SnakeNode*)malloc(sizeof(struct SnakeNode));head->row = 2;head->col = 2;head->next = NULL;tail = head;addNode();addNode();
}void addNode()
{  struct SnakeNode* node = (struct SnakeNode*)malloc(sizeof(struct SnakeNode));node->row = tail->row;node->col = tail->col + 1;node->next = NULL;tail->next = node;tail = node;
}void deleteNode()
{struct SnakeNode* p;p = head;head = head->next;free(p);
}void moveSnake()
{addNode();deleteNode();// if snake is over.if(tail->row == 0 || tail->col == 0 || tail->row >= 20 || tail->col >= 19){snakeinit();}
}void cursesinit()
{initscr();keypad(stdscr,1);
}int hasSnake(int row,int col)
{struct SnakeNode* p = head;while(p!=NULL){if(row == p->row && col == p->col)return 1;p = p->next;}return 0; 
}void mapinit()
{int row;int col;move(0,0);for(row = 0;row < 20;row++){// oneif(row == 0 || row == 19){for(col = 0;col < 19;col++)printw("--");}// twoelse{for(col = 0;col < 20;col++){if(col == 0 || col == 19 ) printw("|");else if(hasSnake(row,col)){printw("[]");}else{printw("  "); }}}printw("\n");}// game startprintw("By hongzhe\n");
}int main()
{int key;cursesinit();snakeinit();mapinit();while(1){key = getch();if(key == KEY_RIGHT){moveSnake();mapinit(); // fresh map	}}getch();  endwin();return 0;
}

学习打卡

在这里插入图片描述

这篇关于贪吃蛇(五)蛇撞墙的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/525604

相关文章

贪吃蛇代码~~自编~~~

这个是贪吃蛇的代码,没设置加速系统~~自己可以根据自己的需求加功能 #include<stdio.h>#include<windows.h>#include<time.h>#include<stdlib.h>#include<iostream>#define MAX_SIZE 50using namespace std;void Loc(int x,int y);void W

用C语言生成字符贪吃蛇游戏

用C语言生成字符贪吃蛇游戏 1. 引言 贪吃蛇是一个经典的小游戏,玩家通过控制蛇的移动来吃食物,随着食物的增加,蛇的长度也会增加,游戏的难度逐渐提升。本文将介绍如何使用C语言来实现一个简单的字符贪吃蛇游戏。 2. 环境准备 在开始编码之前,需要确认以下开发环境: 编译器: 支持标准C语言的编译器(如gcc)。操作系统: Windows、Linux 或 macOS。终端: 用于显示游戏

贪吃蛇的小游戏--用C语言实现

贪吃蛇的小游戏–用C语言实现 游戏背景 贪吃蛇是久负盛名的游戏,它也和俄罗斯⽅块,扫雷等游戏位列经典游戏的⾏列。 实现基本的功能: • 贪吃蛇地图绘制 • 蛇吃⻝物的功能 (上、下、左、右⽅向键控制蛇的动作) • 蛇撞墙死亡 • 蛇撞⾃⾝死亡 • 计算得分 • 蛇⾝加速、减速 • 暂停游戏 技术要点 C语⾔函数、枚举、结构体、动态内存管理、预处理指令、链表、Win32

vue3,贪吃蛇

<template><div flex items-center justify-center h-100vh w-full relative><div class=""><div class="header"><div>得分: {{ score }}</div><div class="flex"><div w-100>速度: {{ speed }}</div><el-sliderv-model=

MFC对话框贪吃蛇小游戏

花了近一个月的时间,学习了一下VC++深入详解,做了个贪吃蛇小游戏,虽然有很多的瑕疵,但还是想分享一下战果。 说一下思路: ①我们要绘制图形,我们可以用CClientDC(客户区设备上下文,与特定的窗口关联)声明一个dc对象作图。 当然这里我们要画蛇的身体和食物,设置一个食物类和蛇身体结构体 ②我们如何让图形动起来?SetTimer创建一个计时器,KillTimer()用来销毁计时器

大二必做项目贪吃蛇超详解之中篇游戏设计与分析

贪吃蛇系列文章 上篇win32 中篇设计与分析 文章目录 贪吃蛇系列文章1. 地图1. 1 `<locale.h>`本地化1. 2 类项1. 3 setlocale函数1. 4 宽字符的打印1. 5 地图坐标 2. 蛇身和食物3. 数据结构设计4. 游戏流程设计5. 核心逻辑实现分析5. 1 游戏主逻辑5. 2 GameStart5. 2. 1 SetInit5. 2. 2 Welcom

Lesson_for_java_day15--java小练习:贪吃蛇游戏(在控制台上操作)

目的:编写一个贪吃蛇游戏,在控制台中操作。 思路: 1、贪吃蛇游戏中,需要蛇对象,食物对象和操作界面对象。 2、蛇对象中,包含蛇身对象(每个点),所以用容器存储蛇对象。 3、同理食物对象也需要容器存储。 4、操作界面由每个具体的点组成,所以需要一个生成点的类。 5、再将这些对象整合到一个控制游戏过程的对象中,实现游戏的过程。 代码: 生成操作界面的点类: package

WebGL实现HTML5的贪吃蛇3D游戏

js1k.com收集了小于1k的javascript小例子,里面有很多很炫很酷的游戏和特效,今年规则又增加了新花样,传统的classic类型基础上又增加了WebGL类型,以及允许增加到2K的++类型,多次想尝试提交个小游戏但总无法写出让自己满意还能控制在这么小的字节范围。 自己写不出来,站在巨人肩膀总是有机会吧,想起《基于HTML5的电信网管3D机房监控应用》这篇提到的threejs,bab

昔日感觉尚在?在iPhone上与贪吃蛇重逢

最近听闻一款名为Snake ‘97的游戏实现了在iPhone上玩贪吃蛇的想法,而且限时免费,异常欣喜,下载之后,看到这界面的确就像找回当年的感觉,而且开发者还很用心地对按键进行了做旧处理。但是昔日的王者居然沦落到寄生于别的手机上,总不免有一种唏嘘的感觉。   曾几何时,不论是等车还是排队,诺基亚手机上的一个贪吃蛇游戏胜过如今一切歌曲、游戏、社交软件。选择最高难度,一条如脱缰野马(什么比

Amazon Bedrock 实践:零基础创建贪吃蛇游戏

本文探讨了如何利用 Amazon Bedrock 和大型语言模型,快速创建经典的贪吃蛇游戏原型代码。重点展示了利用提示工程,将创新想法高效转化为可运行代码方面的过程。文章还介绍了评估和优化提示词质量的最佳实践。 亚马逊云科技开发者社区为开发者们提供全球的开发技术资源。这里有技术文档、开发案例、技术专栏、培训视频、活动与竞赛等。帮助中国开发者对接世界最前沿技术,观点,和项目,并将中国优秀开发者或