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

C語言實現(xiàn)推箱子代碼

 更新時間:2021年07月11日 09:08:57   作者:菠蘿小馬哥  
這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)推箱子代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了C語言實現(xiàn)推箱子代碼的具體代碼,供大家參考,具體內(nèi)容如下

#include<stdio.h>
#include<stdlib.h>
#include<getch.h>//調(diào)用getch函數(shù)

int main()
{
 char arr[8][8] = {
 {0,0,3,3,3,3,0,0},
 {0,0,3,5,5,3,0,0}, 
 {0,3,3,0,5,3,3,0}, 
 {0,3,0,0,4,5,3,0},  
 {3,3,0,4,0,0,3,3},  
 {3,0,0,3,4,4,0,3},
 {3,0,0,2,0,0,0,3},
 {3,3,3,3,3,3,3,3}};//定義一個二位數(shù)組,模擬地圖
 int m_x=6,m_y=3;//給定人的位置
 int cnt=0;
 while(1)//進(jìn)入死循環(huán),達(dá)到給定條件才能結(jié)束循環(huán)
 {
  int cnt2=0;
  system("clear");//清理屏幕
  for(int i=0;i<8;i++)
  {
   for(int j=0;j<8;j++)
   {
    if(arr[i][j]==0) printf(" ");
    else if(arr[i][j]==2) printf("@"); 
    else if(arr[i][j]==3) printf("#");
    else if(arr[i][j]==4) printf("$");
    else if(arr[i][j]==5) printf("o");
    else if(arr[i][j]==7) printf("@");
    else if(arr[i][j]==9)
    {
     printf("$");//每一個數(shù)字代表的字符并打印
     cnt2++;箱子進(jìn)入指定位置+1
    }
   }
   printf("\n");
  }
  if(cnt2==4)//所有箱子到達(dá)給定位置,結(jié)束循環(huán)
  {
   printf("恭喜過關(guān)!一共走了%d步!\n",cnt);
   return 0;
  }
  switch(getch())//獲取方向鍵
  {
   case 183:if(arr[m_x-1][m_y]!=3)//183 方向鍵 上,判斷下個位置是否是墻
   {
    if(arr[m_x-1][m_y]==0||arr[m_x-1][m_y]==5)//判斷下個位置是否是路
    {
     arr[m_x-1][m_y]+=2;//小人到達(dá)下一個位置
     arr[m_x--][m_y]-=2;//原位置清空
    }
    else if(arr[m_x-1][m_y]==4||arr[m_x-1][m_y]==9)//判斷下個位置是否是箱子
    {
     if(arr[m_x-2][m_y]!=3&&arr[m_x-2][m_y]!=4)//判斷下下個位置是否是路
     {
      arr[m_x-2][m_y]+=4;//下下個位置變成箱子
      arr[m_x-1][m_y]-=2;//下個位置變成人
      arr[m_x--][m_y]-=2;//原位置清空
     }
    }
   }
   break;
   case 184:if(arr[m_x+1][m_y]!=3)//方向鍵 下
   {
    if(arr[m_x+1][m_y]==0||arr[m_x+1][m_y]==5)
    {
     arr[m_x+1][m_y]+=2;
     arr[m_x++][m_y]-=2;
    }
    else if(arr[m_x+1][m_y]==4||arr[m_x+1][m_y]==9)
    {
     if(arr[m_x+2][m_y]!=3&&arr[m_x+2][m_y]!=4)
     {
      arr[m_x+2][m_y]+=4;
      arr[m_x+1][m_y]-=2;
      arr[m_x++][m_y]-=2;
     }
    }
   }
   break;
   case 185:if(arr[m_x][m_y+1]!=3)//放向鍵 右
   {
    if(arr[m_x][m_y+1]==0||arr[m_x][m_y+1]==5)
    {
     arr[m_x][m_y+1]+=2;
     arr[m_x][m_y++]-=2;
    }
    else if(arr[m_x][m_y+1]==4||arr[m_x][m_y+1]==9)
    {
     if(arr[m_x][m_y+2]!=3&&arr[m_x+2][m_y]!=4)
     {
      arr[m_x][m_y+2]+=4;
      arr[m_x][m_y+1]-=2;
      arr[m_x][m_y++]-=2;
     }
    }
   }
   break;
   case 186:if(arr[m_x][m_y-1]!=3)//方向鍵 左
   {
    if(arr[m_x][m_y-1]==0||arr[m_x][m_y-1]==5)
    {
     arr[m_x][m_y-1]+=2;
     arr[m_x][m_y--]-=2;
    }
    else if(arr[m_x][m_y-1]==4||arr[m_x][m_y-1]==9)
    {
     if(arr[m_x][m_y-2]!=3&&arr[m_x][m_y]!=4)
     {
      arr[m_x][m_y-2]+=4;
      arr[m_x][m_y-1]-=2;
      arr[m_x][m_y--]-=2;
     }
    }
   }
   break;
  }
  cnt++;//計算走的步數(shù)
 }
 return 0;
}

下面是獲取方向鍵的函數(shù)具體代碼

#ifndef GETCH_H
#define GETCH_H

#include <stdio.h>
#include <termios.h>
#include <unistd.h>

// 修改終端的控制方式,1取消回顯、確認(rèn)?。搏@取數(shù)據(jù) 3還原
static int getch(void)
{
    // 記錄終端的配置信息
    struct termios old;
    // 獲取終端的配置信息
    tcgetattr(STDIN_FILENO,&old);
    // 設(shè)置新的終端配置   
    struct termios _new = old;
    // 取消確認(rèn)、回顯
    _new.c_lflag &= ~(ICANON|ECHO);
    // 設(shè)置終端配置信息
    tcsetattr(STDIN_FILENO,TCSANOW,&_new);

    // 在新模式下獲取數(shù)據(jù)   
    unsigned int key_val = 0; 
    do{
     key_val = key_val+getchar();
    }while(stdin->_IO_read_end - stdin->_IO_read_ptr);

    // 還原配置信息
    tcsetattr(STDIN_FILENO,TCSANOW,&old); 
    return key_val; 
}

#endif//GETCH_H

0表示空格,@表示小人,#表示墻,$表示箱子,O表示箱子需要到達(dá)的位置,數(shù)字7是人與O位置的重合,數(shù)字9是箱子與O位置的重合,也就是到達(dá)了指定位置。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C語言直接插入排序算法介紹及示例

    C語言直接插入排序算法介紹及示例

    插入排序是把一個記錄插入到已排序的有序序列中,使整個序列在插入該記錄后仍然有序。插入排序中較簡單的種方法是直接插入排序,其插入位置的確定方法是將待插入的記錄與有序區(qū)中的各記錄自右向左依次比較其關(guān)鍵字值的大小
    2022-08-08
  • vscode?采用C++17版本進(jìn)行編譯的實現(xiàn)

    vscode?采用C++17版本進(jìn)行編譯的實現(xiàn)

    本文主要介紹了vscode?采用C++17版本進(jìn)行編譯,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • 深入理解c++常成員函數(shù)和常對象

    深入理解c++常成員函數(shù)和常對象

    下面小編就為大家?guī)硪黄钊肜斫鈉++常成員函數(shù)和常對象。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考,一起跟隨小編過來看看吧
    2016-05-05
  • C++聚合關(guān)系類的構(gòu)造函數(shù)的調(diào)用順序詳解

    C++聚合關(guān)系類的構(gòu)造函數(shù)的調(diào)用順序詳解

    下面小編就為大家?guī)硪黄狢++聚合關(guān)系類的構(gòu)造函數(shù)的調(diào)用順序詳解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考,一起跟隨小編過來看看吧
    2016-05-05
  • C++判斷一個點是否在圓內(nèi)的方法

    C++判斷一個點是否在圓內(nèi)的方法

    這篇文章主要為大家詳細(xì)介紹了C++判斷一個點是否在圓內(nèi)的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • C++中int類型按字節(jié)打印輸出的方法

    C++中int類型按字節(jié)打印輸出的方法

    這篇文章主要給大家介紹了關(guān)于C++中int類型按字節(jié)打印輸出的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用C++具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • C++?11新特性之右值引用使用案例與應(yīng)用場景

    C++?11新特性之右值引用使用案例與應(yīng)用場景

    右值引用和move語義是C++ 11中重要的特性之一,可以提高程序的效率和性能,右值引用是一種新的引用類型,下面這篇文章主要給大家介紹了關(guān)于C++?11新特性之右值引用使用案例與應(yīng)用場景的相關(guān)資料,需要的朋友可以參考下
    2024-01-01
  • C語言遞歸函數(shù)與漢諾塔問題簡明理解

    C語言遞歸函數(shù)與漢諾塔問題簡明理解

    遞歸(recursive)函數(shù)是“自己調(diào)用自己”的函數(shù),無論是采用直接或間接調(diào)用方式。間接遞歸意味著函數(shù)調(diào)用另一個函數(shù)(然后可能又調(diào)用第三個函數(shù)等),最后又調(diào)用第一個函數(shù)。因為函數(shù)不可以一直不停地調(diào)用自己,所以遞歸函數(shù)一定具備結(jié)束條件
    2022-07-07
  • C語言實現(xiàn)文本編輯器系統(tǒng)

    C語言實現(xiàn)文本編輯器系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)文本編輯器系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • C語言靜態(tài)版通訊錄的設(shè)計與實現(xiàn)

    C語言靜態(tài)版通訊錄的設(shè)計與實現(xiàn)

    靜態(tài)版通訊錄是一種簡單的通訊錄實現(xiàn)方式,通過定義固定的數(shù)組大小來存儲聯(lián)系人信息。該方法不支持動態(tài)增刪聯(lián)系人,但具有實現(xiàn)簡單、易于理解的優(yōu)點。在程序設(shè)計中,需注意數(shù)組邊界溢出等問題
    2023-04-04

最新評論