首页 > 其他分享 >贪吃蛇!!!

贪吃蛇!!!

时间:2024-07-25 19:29:37浏览次数:11  
标签:head cout int void 贪吃蛇 snake position

Hello!我是love you 的小羊生煎(>-<)

通过我分享的实用技巧和策略,你将在你的领域脱颖而出,引领潮流!

无论你遇到什么挑战,我将一直在你身边,为你提供支持和鼓励!

2话不说上代码

贪吃蛇

#include <windows.h>
#include <stdlib.h>
#include <conio.h>
#include <time.h>
#include <cstring>
#include <cstdio>
#include <iostream>
#define  N 22
using namespace std;

    int gameover;

    int x1, y1; // Ëæ»ú³öÃ×

    int x,y;

    long start;

//=======================================
//ÀàµÄʵÏÖÓëÓ¦ÓÃinitialize
//=======================================

//ÏÂÃ涨ÒåÌ°³ÔÉßµÄ×ø±êÀà
class snake_position
{
public:

    int x,y;      //x±íʾÐУ¬y±íʾÁÐ

    snake_position(){};

    void initialize(int &);//×ø±ê³õʼ»¯


};

snake_position position[(N-2)*(N-2)+1]; //¶¨ÒåÌ°³ÔÉß×ø±êÀàÊý×飬ÓÐ(N-2)*(N-2)¸ö×ø±ê

void snake_position::initialize(int &j)
{
        x = 1;

        y = j;
}


//ÏÂÃ涨ÒåÌ°³ÔÉßµÄÆåÅÌͼ

class snake_map
{

private:

    char s[N][N];//¶¨ÒåÌ°³ÔÉßÆåÅÌ£¬°üÀ¨Ç½±Ú¡£

    int grade, length;

    int gamespeed; //Ç°½øʱ¼ä¼ä¸ô

    char direction; // ³õʼÇé¿öÏ£¬ÏòÓÒÔ˶¯

    int head,tail;

    int score;

    bool gameauto;

public:

    snake_map(int h=4,int t=1,int l=4,char d=77,int s=0):length(l),direction(d),head(h),tail(t),score(s){}

    void initialize();   //³õʼ»¯º¯Êý

    void show_game();

    int updata_game();

    void setpoint();

    void getgrade();

    void display();


};

//¶¨Òå³õʼ»¯º¯Êý£¬½«Ì°³ÔÉßµÄÆåÅÌͼ½øÐгõʼ»¯

void snake_map::initialize()
{
    int i,j;

    for(i=1;i<=3;i++)

        s[1][i] = '*';

    s[1][4] = '#';

    for(i=1;i<=N-2;i++)

        for(j=1;j<=N-2;j++)

            s[i][j]=' '; // ³õʼ»¯Ì°³ÔÉßÆåÅÌÖмä¿Õ°×²¿·Ö

    for(i=0;i<=N-1;i++)

        s[0][i] = s[N-1][i] = '-'; //³õʼ»¯Ì°³ÔÉßÆåÅÌÉÏÏÂǽ±Ú

    for(i=1;i<=N-2;i++)

        s[i][0] = s[i][N-1] = '|'; //³õʼ»¯Ì°³ÔÉßÆåÅÌ×óÓÒǽ±Ú
}


//============================================
//Êä³öÌ°³ÔÉßÆåÅÌÐÅÏ¢

void snake_map::show_game()

{

    system("cls"); // ÇåÆÁ

    int i,j;

    cout << endl;

    for(i=0;i<N;i++)
    {

        cout << '\t';

        for(j=0;j<N;j++)

            cout<<s[i][j]<<' '; // Êä³öÌ°³ÔÉßÆåÅÌ

        if(i==2) cout << "\tµÈ¼¶£º" << grade;

        if(i==6) cout << "\tËٶȣº" << gamespeed;

        if(i==10) cout << "\tµÃ·Ö£º" << score << "·Ö" ;

        if(i==14) cout << "\tÔÝÍ££º°´Ò»Ï¿ոñ¼ü" ;

        if(i==18) cout << "\t¼ÌÐø£º°´Á½Ï¿ոñ¼ü" ;

        cout<<endl;
    }
}

//ÊäÈëÑ¡ÔñµÈ¼¶
void snake_map::getgrade()
{
    cin>>grade;

    while( grade>7 || grade<1 )
    {
        cout << "ÇëÊäÈëÊý×Ö1-7Ñ¡ÔñµÈ¼¶£¬ÊäÈëÆäËûÊý×ÖÎÞЧ" << endl;

        cin >> grade;
    }
    switch(grade)
    {
        case 1: gamespeed = 1000;gameauto = 0;break;

        case 2: gamespeed = 800;gameauto = 0;break;

        case 3: gamespeed = 600;gameauto = 0;break;

        case 4: gamespeed = 400;gameauto = 0;break;

        case 5: gamespeed = 200;gameauto = 0;break;

        case 6: gamespeed = 100;gameauto = 0;break;

        case 7: grade = 1;gamespeed = 1000;gameauto = 1;break;

    }

}

//Êä³öµÈ¼¶£¬µÃ·ÖÇé¿öÒÔ¼°³ÆºÅ

void snake_map::display()
{

    cout << "\n\t\t\t\tµÈ¼¶£º" << grade;

    cout << "\n\n\n\t\t\t\tËٶȣº" << gamespeed;

    cout << "\n\n\n\t\t\t\tµÃ·Ö£º" << score << "·Ö" ;

}

//Ëæ»ú²úÉúÃ×
void snake_map::setpoint()
{
    srand(time(0));

    do
    {

        x1 = rand() % (N-2) + 1;

        y1 = rand() % (N-2) + 1;

    }while(s[x1][y1]!=' ');

    s[x1][y1]='*';
}

char key;

int snake_map::updata_game()
{
    gameover = 1;

    key = direction;

    start = clock();

    while((gameover=(clock()-start<=gamespeed))&&!kbhit());

    //Èç¹ûÓмü°´Ï»òʱ¼ä³¬¹ý×Ô¶¯Ç°½øʱ¼ä¼ä¸ôÔòÖÕֹѭ»·

        if(gameover)
        {

            getch();

            key = getch();
        }

        if(key == ' ')

        {
            while(getch()!=' '){};//ÕâÀïʵÏÖµÄÊÇ°´¿Õ¸ñ¼üÔÝÍ££¬°´¿Õ¸ñ¼ü¼ÌÐøµÄ¹¦ÄÜ£¬µ«²»ÖªÎªºÎÔ­Òò£¬ÐèÒª°´Á½Ï¿ոñ²ÅÄܼÌÐø¡£ÕâÊǸöbug¡£
        }

        else

            direction = key;

        switch(direction)
        {
            case 72: x= position[head].x-1; y= position[head].y;break; // ÏòÉÏ

            case 80: x= position[head].x+1; y= position[head].y;break; // ÏòÏÂ

            case 75: x= position[head].x; y= position[head].y-1;break; // Ïò×ó

            case 77: x= position[head].x; y= position[head].y+1; // ÏòÓÒ

        }

        if(!(direction==72||direction==80||direction==75 ||direction==77))   // °´¼ü·Ç·½Ïò¼ü

            gameover = 0;

        else if(x==0 || x==N-1 ||y==0 || y==N-1)   // Åöµ½Ç½±Ú

            gameover = 0;

        else if(s[x][y]!=' '&&!(x==x1&&y==y1))    // ÉßÍ·Åöµ½ÉßÉí

            gameover = 0;

        else if(x==x1 && y==y1)

        { // ³ÔÃ×£¬³¤¶È¼Ó1

            length ++;

            if(length>=8 && gameauto)

            {

                length -= 8;

                grade ++;

                if(gamespeed>=200)

                    gamespeed -= 200; // ¸Ä±äÌ°³ÔÉßÇ°½øËÙ¶È

                else

                    gamespeed = 100;

            }

            s[x][y]= '#';  //¸üÐÂÉßÍ·

            s[position[head].x][position[head].y] = '*'; //³ÔÃ׺ó½«Ô­ÏÈÉßÍ·±äΪÉßÉí

            head = (head+1) % ( (N-2)*(N-2) );   //È¡ÉßÍ·×ø±ê

            position[head].x = x;

            position[head].y = y;

            show_game();

            gameover = 1;

            score += grade*20;  //¼Ó·Ö

            setpoint();   //²úÉúÃ×

        }

        else
        { // ²»³ÔÃ×

            s[position[tail].x][position[tail].y]=' ';//½«ÉßβÖÿÕ

            tail= (tail+1) % ( (N-2) * (N-2) );//¸üÐÂÉßβ×ø±ê

            s[position[head].x][position[head].y]='*';  //½«ÉßÍ·¸üΪÉßÉí

            head= (head+1) % ( (N-2) * (N-2) );

            position[head].x = x;

            position[head].y = y;

            s[position[head].x][position[head].y]='#'; //¸üÐÂÉßÍ·

            gameover = 1;

        }
    return gameover;

}
//====================================
//Ö÷º¯Êý²¿·Ö
//====================================
int main()
{
    char ctn = 'y';

    int nodead;

    cout<<"\n\n\n\n\n\t\t\t »¶Ó­½øÈëÌ°³ÔÉßÓÎÏ·!"<<endl;//»¶Ó­½çÃæ;

    cout<<"\n\n\n\t\t\t °´ÈÎÒâ¼üÂíÉÏ¿ªÊ¼¡£¡£¡£"<<endl;//×¼±¸¿ªÊ¼;;

    getch();

    while( ctn=='y' )
    {
        system("cls"); // ÇåÆÁ

        snake_map snake;

        snake.initialize();

        cout << "\n\nÇëÊäÈëÊý×ÖÑ¡ÔñÓÎÏ·µÈ¼¶£º" << endl;

        cout << "\n\n\n\t\t\t1.µÈ¼¶Ò»£ºËÙ¶È 1000 \n\n\t\t\t2.µÈ¼¶¶þ£ºËÙ¶È 800 \n\n\t\t\t3.µÈ¼¶Èý£ºËÙ¶È 600 ";

        cout << "\n\n\t\t\t4.µÈ¼¶ËÄ£ºËÙ¶È 400 \n\n\t\t\t5.µÈ¼¶Î壺ËÙ¶È 200 \n\n\t\t\t6.µÈ¼¶Áù£ºËÙ¶È 100 \n\n\t\t\t7.×Ô¶¯Éý¼¶Ä£Ê½" << endl;

        snake.getgrade();//»ñÈ¡µÈ¼¶

        for(int i=1;i<=4;i++)
        {
            position[i].initialize(i);//³õʼ»¯×ø±ê
        }

        snake.setpoint();  // ²úÉúµÚÒ»¸öÃ×

        do
        {
            snake.show_game();

            nodead = snake.updata_game();

        }while(nodead);

        system("cls"); //ÇåÆÁ

        cout << "\n\n\n\t\t\t\tGameover£¡\n\n"<<endl;

        snake.display();//Êä³öµÈ¼¶/µÃ·ÖÇé¿ö

        cout << "\n\n\n\t\t    ÊÇ·ñÑ¡Ôñ¼ÌÐøÓÎÏ·£¿ÊäÈë y ¼ÌÐø£¬n Í˳ö" << endl;

        cin >> ctn;

    }

    return 0;
}

点赞是给我最大的动力!!!

标签:head,cout,int,void,贪吃蛇,snake,position
From: https://blog.csdn.net/2401_83259703/article/details/140633910

相关文章

  • 基于c语言的贪吃蛇小游戏附带源码
    #include<stdio.h>#include<conio.h>#include<windows.h>#include<time.h>#defineframex5#defineframey5#definewide20#definehigh20inti,j,a[2];//将光标移动到指定位置voidgotoxy(HANDLEhout,intx,inty){//COORD是WindowsAPI中定义......
  • 控制台小游戏制作——贪吃蛇
    Game.csusingSystem;usingSystem.Collections.Generic;usingSystem.Text;using贪食蛇.Lesson2;namespace贪食蛇.Lesson1{///<summary>///场景类型枚举///</summary>enumE_SceneType{///<summary>///开始场景......
  • 【Qt】探索Qt框架:开发经典贪吃蛇游戏的全过程与实践
    文章目录引言项目链接:1.Qt框架的使用简介2.贪吃蛇游戏设计2.1游戏规则和玩法介绍2.2游戏界面设计概述3.核心代码解析3.1主界面(GameHall)3.1.1布局和功能介绍3.1.2代码实现分析3.2游戏选择界面(GameSelect)3.2.1功能介绍3.2.2代码实现分析3.3游戏房间(GameRoom......
  • 贪吃蛇游戏
    前言本篇博客为大家介绍C语言中的一个比较重要的项目——贪吃蛇游戏,这个游戏的实现需要充分运用C语言的相关知识,所以大家一定要提前学好C语言的知识,再来做贪吃蛇的项目;如果你对本文内容感兴趣,请继续往下阅读,下面我们进入正文部分。1.游戏背景贪吃蛇是久负盛名的游戏,它也和俄......
  • 贪吃蛇完整代码解析
    1.1头文件点击查看代码#include<stdio.h>#include<curses.h>//包含curses插件#include<stdlib.h>//srand#include<unistd.h>//sleep头文件#include<stdbool.h>//bool条件判断#include<pthread.h>//线程头文件#include<time.h>//时间头文件......
  • 贪吃蛇代码第一天
    1.1初始化curses初始化cursesvoidinitscr_func(){initscr();keypad(stdscr,true);}1.2创建贪吃蛇点击查看代码//贪吃蛇创建snake_t*create_snake(introw,intcol){snake_head=(snake_t*)malloc(sizeof(snake_t));//蛇头分配内存s......
  • html+css+js贪吃蛇游戏
    贪吃蛇游戏......
  • C语言实战项目:贪吃蛇游戏(SnakeGame)
    前言:前面C语言的基础语法和数据结构的顺序表、链表已经学完了,我们就已经有能力去实现一个贪吃蛇项目。我们可以实现一些贪吃蛇的一些功能,例如:食物的随机生成、贪吃蛇的长度、贪吃蛇加速和减速、暂停游戏、贪吃蛇的游戏结束判定等...如下图所示:图片仅限参考真实项目视频:20......
  • C语言编程-基于单链表实现贪吃蛇游戏
    基于单链表实现贪吃蛇游戏1.定义结构体参数蛇行走的方向蛇行走的状态蛇身节点类维护蛇的结构体型2.游戏运行前预备工作定位光标位置游戏欢迎界面绘制游戏地图(边界)初始化游戏中的蛇身创建食物3.游戏运行下一个位置是食物,就吃掉食物,释放该节点下一个位置不是......
  • 【华为OD机试真题】238、贪吃蛇 | 机试真题+思路参考+代码分析(C++、Java、Py、JS)
    文章目录一、题目......