欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

c++實現(xiàn)超簡單的貪吃蛇游戲?qū)嵗榻B

 更新時間:2021年12月20日 10:55:21   作者:Krito.  
大家好,本篇文章主要講的是c++實現(xiàn)超簡單的貪吃蛇游戲?qū)嵗榻B,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽

設計思路

? ? ? ??建議先將代碼復制下來跑一遍再來看思路?。?!

? ? ? ? 通俗易懂,請仔細看。

? ? ? ? 值得注意的是我給出的代碼沒有加墻體,如有需要自己添加。

? ? ? ? 也沒有難度設計,同上。

地圖大?。ㄟ@里設計了墻體,代碼中未實現(xiàn))

設置一個整形數(shù)組map,其大小為1600,對應著地圖的大小為1600,并初始化數(shù)組,令數(shù)組中的值全為0,0代表空地。

我們通過設定窗口的寬度為80,打印時每個map[i] 所對應的字符占兩格位置即可實現(xiàn)每打印40個map[i]就換行的效果。

這樣地圖的長寬即為40x40.

? ? ? 2.墻體

墻體在地圖的最外圍,意味著當map[i]中的i為地圖邊界時,對應著墻體,使用if語句判斷i的值,符合位于邊界的條件打印墻體即可。

通過地圖的大小我們了解到,當0<=i<=39時,map[i]對應著第一行,也就是地圖的邊界 ,同樣的,地圖左邊界的i滿足i%40==0,右邊界的i滿足(i+1)%40==0,,同理下邊界。將上述符合的條件放入if語句中即可實現(xiàn)打印墻體的功能。

? ? ? ? 3.蛇

蛇是如何移動呢?并且保持一定長度。其實我們只需要一個蛇頭就可以辦到,因為蛇身只是舊蛇頭的位置,所以我們一直只需更新蛇頭坐標就能達到目的,如何保持長度呢?,因為我們更新新的蛇頭,去掉舊的蛇尾是很顯然的事了,在地圖大小中我們提到,map[i] 如果等于0,就是空地,讓蛇尾的值變成0就行了,因為蛇一直在移動,所以當前蛇尾的前一節(jié)蛇身會是下一刻的蛇尾,很自然的聯(lián)想到了以1為公差的一組數(shù)1234,分別對應蛇身的值,如果我們想使蛇連續(xù)的動起來,新蛇頭的值為4,在加入新蛇頭前將蛇尾變?yōu)?,蛇尾前一節(jié)蛇身變?yōu)榇丝躺呶矊闹禐?,使蛇整體減去1,此時的蛇的值為0123,加入蛇頭4,01234,此刻原蛇尾變?yōu)榭盏?,原蛇尾前一截蛇身變?yōu)榇丝痰纳呶?。貪吃蛇的持續(xù)移動便完成了。

? ? ? ?4.食物

很自然的,在上面3節(jié)map[i]為0,正整數(shù)時都有了對應的含義,食物我們便使其 map[i] =-1.因為貪吃蛇游戲中食物的生成要求是隨機的,但我們的c++課程中并沒有提到,便在網(wǎng)上查找到了隨機數(shù)生成的函數(shù)srand(上面的設定窗口大小也是如此),生成的隨機數(shù)i可能超出數(shù)組大小,對i取1600的余數(shù)即可。食物只能生成在空地上,當map[i]等于0時,令map[i]=-1。新的食物便生成了。容易忽略的一點是,我們并沒有給墻體map[i]的值,也就是所墻體的值在數(shù)組中對應的是空地,只不過通過i的位置來判斷是否為墻體,在這里,同樣也要加入墻體的位置到判斷條件,以免食物生成在墻體內(nèi)。新的食物在舊的食物被吃掉后立即生成。

? ? ? 5.死亡判定

我們通過新蛇頭所對應的值來判斷蛇是否死亡

? ? ? ? (1)map[headx+heady*40]>0, 由3我們可以知道,蛇身所對應的map [i] ?值大于0,新蛇頭所對應的map值大于0也就意味著新蛇頭在蛇身生成,按

照貪吃蛇的規(guī)則,游戲結(jié)束

? ? ? ?(2)(headx+heady*40)滿足墻體的打印條件時,意味著蛇頭在墻體生成,游戲結(jié)束

實現(xiàn)代碼

#include<bits/stdc++.h>
#include<windows.h>
#include<iostream>
#include<conio.h>
int main() {
    int headx = 0, heady = 0, len = 5, map[1600] = { 0 }, i = 0;
    char c = 'd', cl = 'd',body=3,head=2;
    /*隨機數(shù)生成*/
    srand((unsigned)time(0));
    system("mode con:cols=80 lines=40");
    map[rand() % 1600] = -1;
    while (true)
    {
        if (_kbhit())//判斷鍵盤輸入
        {
            cl =_getch();
            if (cl < 97) cl += 32;
            if (cl == 'a' && c != 'd' || cl == 'd' && c != 'a' ||cl == 'w' && c != 's' || cl == 's' && c != 'w')//判斷輸入方向是否與原方向沖突
                c = cl;
        }
        /*改變蛇頭坐標*/
        if (c == 'a') headx--;
        if (c == 'd') headx++;
        if (c == 'w') heady--;
        if (c == 's') heady++;
        /*判斷蛇頭是否撞墻*/
        if(headx==-1||headx==40||heady==-1||heady==40)
            break;
        /*判斷蛇頭是否為空地*/
        if (map[heady * 40 + headx])
        {
            if (map[heady * 40+headx] > 0) break;
            /*吃到食物,蛇身+1,并在空地生成新的食物*/
            if (map[heady * 40 + headx] < 0)
            {
                len++;
                for (i = rand() % 1600; map[i] || !(map[i] = -1); i = rand() % 1600);
            }
        }
        /*是空地則蛇身值整體減1,蛇尾由1減為0變成空地*/
        else for (i = 0; i < 1600; i++)
        {
            if (map[i] > 0) map[i] -= 1;
        }
        system("cls");
        /*新蛇頭賦值,遍歷map,值大于0為蛇身,等于0為空地,小于0為食物*/
        for (map[heady * 40 + headx] = len, i = 0; i < 1600; i++)
        {
            if (map[i] == len) {
                printf("%2d", map[i]);
                continue;
            }
            if (map[i] > 0)  printf("%2d", map[i]);
            if (map[i] == 0)  printf("%2d", map[i]);
            if (map[i] == -1) printf("%2d", map[i]);//打印
         }
        Sleep(100);
    }
}

效果

?如果你仔細閱讀了代碼,將數(shù)字替換成你想要的符號(占兩個字符大小如果是一個字符要加一個空格)是很簡單的事情

如果你想要游戲循環(huán)進行,也是很容易辦到的。

這只是個demo,你可以根據(jù)自己的需要任意的改寫。

到此這篇關(guān)于c++實現(xiàn)超簡單的貪吃蛇游戲?qū)嵗榻B的文章就介紹到這了,更多相關(guān)c++貪吃蛇游戲內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • VC實現(xiàn)讓關(guān)閉按鈕成灰色不可用的方法

    VC實現(xiàn)讓關(guān)閉按鈕成灰色不可用的方法

    這篇文章主要介紹了VC實現(xiàn)讓關(guān)閉按鈕成灰色不可用的方法,比較實用的一個特殊功能,需要的朋友可以參考下
    2014-08-08
  • C++?雙向循環(huán)鏈表類模版實例詳解

    C++?雙向循環(huán)鏈表類模版實例詳解

    這篇文章主要為大家詳細介紹了C++?雙向循環(huán)鏈表類模版實例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • C++動態(tài)內(nèi)存分配超詳細講解

    C++動態(tài)內(nèi)存分配超詳細講解

    給數(shù)組分配多大的空間?你是否和初學C時的我一樣,有過這樣的疑問。這一期就來聊一聊動態(tài)內(nèi)存的分配,讀完這篇文章,你可能對內(nèi)存的分配有一個更好的理解
    2022-08-08
  • C++控制臺實現(xiàn)隨機生成路徑迷宮游戲

    C++控制臺實現(xiàn)隨機生成路徑迷宮游戲

    這篇文章主要為大家詳細介紹了C++控制臺實現(xiàn)隨機生成路徑迷宮游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • C++設計模式之狀態(tài)模式

    C++設計模式之狀態(tài)模式

    這篇文章主要介紹了C++設計模式之狀態(tài)模式,本文講解了什么是狀態(tài)模式、狀態(tài)模式的使用場合、狀態(tài)模式的實現(xiàn)代碼等內(nèi)容,需要的朋友可以參考下
    2014-10-10
  • 淺析C++中的重載,隱藏和覆蓋

    淺析C++中的重載,隱藏和覆蓋

    在C++語言中,函數(shù)扮演著很重要的角色,不管面向過程設計,還是基于對象設計。本文主要為大家介紹了函數(shù)中重載、覆蓋和隱藏的相關(guān)知識,感興趣的小伙伴可以了解一下
    2022-12-12
  • 解析C++多文件編程問題

    解析C++多文件編程問題

    在某些場景中,考慮到編譯效率和可移植性,#pragma once 和 #ifndef 經(jīng)常被結(jié)合使用來避免頭文件被 重復引入,這里介紹用 _Pragma 操作符避免頭文件重復引入的問題,感興趣的朋友跟隨小編一起看看吧
    2021-10-10
  • C語言goto語句簡單使用詳解

    C語言goto語句簡單使用詳解

    C語言中提供了可以隨意濫用的 goto語句和標記跳轉(zhuǎn)的標號,本文主要介紹了C語言goto語句簡單使用詳解,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • C#開源類庫SimpleTCP使用方法

    C#開源類庫SimpleTCP使用方法

    SimpleTCP內(nèi)部有一個特殊字符分割字符串的協(xié)議可以直接使用,也可以在DataReceived事件處理程序中實現(xiàn)自己的協(xié)議,這篇文章主要介紹了C#開源類庫SimpleTCP的使用方法,需要的朋友可以參考下
    2021-09-09
  • 如何利用C語言實現(xiàn)最簡單的HTTP服務器詳解

    如何利用C語言實現(xiàn)最簡單的HTTP服務器詳解

    這篇文章主要給大家介紹了關(guān)于如何利用C語言實現(xiàn)最簡單的HTTP服務器的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用C語言具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-11-11

最新評論