全系列Index:

  1. 【原创】只学到二维数组和结构体,不用链表也能写一个C贪食蛇?(一)
  2. 【原创】只学到二维数组和结构体,不用链表也能写一个C贪食蛇?(二)
  3. 【原创】只学到二维数组和结构体,不用链表也能写一个C贪食蛇?(三)
  4. 【原创】只学到二维数组和结构体,不用链表也能写一个C贪食蛇?(四)

由于用system("cls")重绘会有较大的闪烁,我google了网上GOTOXY的实现来完成帧的重绘。

全部程序的源代码:

/*
Powered by wmydx
Snake verson 2.0
2013.10.19
verson 1.0的遗留问题已经解决:标记蛇头的访问顺序,谁小跟谁
注意:用户摁键过快会产生BUG,已解决
*/
#include <stdio.h>
#include <conio.h>
#include <windows.h>
#include <time.h>
#define ROW 40
#define COL 20
struct SnakeTail
{
int x;
int y;
};
struct SnakeHead
{
int x;
int y;
int dis;
};
struct Food
{
int x;
int y;
};
struct Map
{
char a;
unsigned long long num;
};
struct Point
{
int x;
int y;
int flag;
};
SnakeTail myTail;
SnakeHead myHead;
Food myFood;
unsigned long long count = ;
Map map[COL][ROW];
int gameSpeed = ;
int winPoint = ;
int isDead = ;
int isPoint = ;
//以下是网上找来的GOTOXY实现
void GoToXY(int x, int y)
{
COORD pos = {x,y};
HANDLE hOut = GetStdHandle(STD_OUTPUT_HANDLE); // 获取标准输出设备句柄 SetConsoleCursorPosition(hOut, pos);
} void WhereXY(int *x, int *y)
{
HANDLE hOut = GetStdHandle(STD_OUTPUT_HANDLE); // 获取标准输出设备句柄
CONSOLE_SCREEN_BUFFER_INFO bInfo;
GetConsoleScreenBufferInfo( hOut, &bInfo );
COORD pos = bInfo.dwCursorPosition;
*x = pos.X;
*y = pos.Y;
}
//以上时网上找来的GOTOXY实现
void plantFood()
{
int tmpx,tmpy;
srand((int)time());
tmpx = rand() % COL;
tmpy = rand() % ROW;
while(((tmpx <= && tmpx >= COL - ) || (tmpy <= && tmpy >= ROW - )) || map[tmpx][tmpy].a == '*')
{
tmpx = rand() % COL;
tmpy = rand() % ROW;
}
myFood.x = tmpx;
myFood.y = tmpy;
map[myFood.x][myFood.y].a = '$';
}
void initialization() //初始化游戏
{
int col = ;
for(int i = ;i < COL;i++)
for(int j = ;j < ROW;j++)
{
map[i][j].a = ' ';
map[i][j].num = ;
}
for(int i = ;i <= ;i++)
{
map[col][i].a = '*';
map[col][i].num = count ++;
}
myTail.x = ;
myTail.y = ;
myHead.x = ;
myHead.y = ;
myHead.dis = ;
plantFood();
}
void print()
{
printf(" ");
for(int i = ;i < ROW;i++)
printf("-");
printf("\n");
for(int i = ;i < COL;i++)
{
printf(" ");
for(int j = ;j < ROW;j++)
{
if(j == )printf("|");
printf("%c",map[i][j].a);
}
printf("|\n");
}
printf(" ");
for(int i = ;i < ROW;i++)
printf("-");
}
int ifDie(int x,int y)
{
if(x < || y < || x >= COL || y >= ROW || map[x][y].a == '*')return ;
else return ;
}
int ifGetPoint()
{
if(map[myHead.x][myHead.y].a == '$')
{
plantFood();
return ;
}
else return ;
}
void deleteTail()
{
Point a[];
Point temp;
int test = ;
unsigned long long min = 0xFFFFFFFF;
for(int i = ;i < ;i++)
a[i].flag = ;
if(map[myTail.x + ][myTail.y].a == '*')
{
a[].flag = ;
a[].x = myTail.x + ;
a[].y = myTail.y;
}
if(map[myTail.x - ][myTail.y].a == '*')
{
a[].flag = ;
a[].x = myTail.x - ;
a[].y = myTail.y;
}
if(map[myTail.x][myTail.y + ].a == '*')
{
a[].flag = ;
a[].x = myTail.x;
a[].y = myTail.y + ;
}
if(map[myTail.x][myTail.y - ].a == '*')
{
a[].flag = ;
a[].x = myTail.x;
a[].y = myTail.y - ;
}
for(int i = ;i < ;i++)
{
if(a[i].flag == )
{
test ++;
if(map[a[i].x][a[i].y].num < min)
{
min = map[a[i].x][a[i].y].num;
temp = a[i];
} }
}
map[myTail.x][myTail.y].a = ' ';
map[myTail.x][myTail.y].num = ;
myTail.x = temp.x;
myTail.y = temp.y;
}
void snakeMove()
{
switch(myHead.dis)
{
case : myHead.x --;
if(ifGetPoint())
{
winPoint ++;
isPoint = ;
}
if(!ifDie(myHead.x,myHead.y))
{
map[myHead.x][myHead.y].a = '*';
map[myHead.x][myHead.y].num = count ++;
}
else
{
isDead = ;
}
break;
case : myHead.x ++;
if(ifGetPoint())
{
winPoint ++;
isPoint = ;
}
if(!ifDie(myHead.x,myHead.y))
{
map[myHead.x][myHead.y].a = '*';
map[myHead.x][myHead.y].num = count ++;
}
else
{
isDead = ;
}
break;
case : myHead.y --;
if(ifGetPoint())
{
winPoint ++;
isPoint = ;
}
if(!ifDie(myHead.x,myHead.y))
{
map[myHead.x][myHead.y].a = '*';
map[myHead.x][myHead.y].num = count ++;
}
else
{
isDead = ;
}
break;
case : myHead.y ++;
if(ifGetPoint())
{
winPoint ++;
isPoint = ;
}
if(!ifDie(myHead.x,myHead.y))
{
map[myHead.x][myHead.y].a = '*';
map[myHead.x][myHead.y].num = count ++;
}
else
{
isDead = ;
}
break;
}
if(isPoint == )
{
deleteTail();
}
else isPoint = ;
}
void changeSnake(char ch)
{
if(ch == '.')return;
switch(ch)
{
case 'w' : if(myHead.dis != )myHead.dis = ;
break;
case 'a' : if(myHead.dis != )myHead.dis = ;
break;
case 's' : if(myHead.dis != )myHead.dis = ;
break;
case 'd' : if(myHead.dis != )myHead.dis = ;
break;
default : ;//printf("ERROR!"); BUG检测代码
}
}
int main(void)
{
char control = '.';
initialization();
int end = ;
while()
{
while(kbhit() == )
{
changeSnake(control); //这个函数要放入循环体!否则摁键过快,前次操作未进入循环体,后次操作又改变dis了
control = '.';
print();
snakeMove();
if(isDead == )
{
end = ;
break;
}
Sleep(gameSpeed);
GoToXY(,);
}
if(end)break;
control = getch();
}
printf("\n YOUR SCORE IS %d \n",winPoint);
system("pause");
return ;
}

【原创】只学到二维数组和结构体,不用链表也能写一个C贪食蛇?(四)的更多相关文章

  1. C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | IT宅.com

    原文:C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | IT宅.com C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | I ...

  2. C语言一维数组、二维数组、结构体的初始化

    C语言数组的初始化表示方法 一.C语言一维数组初始化: (1)在定义数组时对数组元素赋以初值.如: static int a[10]={0,1,2,3,4,5,6,7,8,9}; 经过上面的定义和初始 ...

  3. 晓莲说-何不原创:java 实现二维数组冒泡排序

    新手从业路-为自己回顾知识的同时,也希望和大家分享经验: 话不多说,上代码 public class 冒泡排序 { /**     * @param admin     * @2017.12.4   ...

  4. php根据二维数组中的某一元素相等,另一个元素相加

    二维数组:$taskData Array ( [0] => Array ( [area] => 1 [winsFlag] => 7 [count] => 3 ) [1] =&g ...

  5. 【Java学习笔记之八】java二维数组及其多维数组的内存应用拓展延伸

    多维数组声明 数据类型[][] 数组名称; 数据类型[] 数组名称[]; 数据类型数组名称[][]; 以上三种语法在声明二维数组时的功能是等价的.同理,声明三维数组时需要三对中括号,中括号的位置可以在 ...

  6. 数组属性的习题、Arrays工具、二维数组

    一.数组的练习 1.声明一个char类型的数组, 从键盘录入6个字符: [1]遍历输出 [2]排序 [3]把char数组转化成一个逆序的数组. import java.util.Scanner; pu ...

  7. 常用的Arrays类和二维数组以及二分法的介绍

    ---恢复内容开始--- 1.Array类 Array中包含了许多数组的常用操作,较为常见的有: (1)快速输出 import java.util.Arrays; public class Test{ ...

  8. Java数组之二维数组

    Java中除了一维数组外,还有二维数组,三维数组等多维数组.本文以介绍二维数组来了解多维数组. 1.二维数组的基础 二维数组的定义:二维数组就是数组的数组,数组里的元素也是数组. 二维数组表示行列二维 ...

  9. java se系列(四) 函数、数组、排序算法、二分法、二维数组

    1 函数 1.1  数的概述 发现不断进行加法运算,为了提高代码的复用性,就把该功能独立封装成一段独立的小程序,当下次需要执行加法运算的时候,就可以直接调用这个段小程序即可,那么这种封装形形式的具体表 ...

随机推荐

  1. 祝贺自己itpub和csdn双双荣获专家博客标题

    这是业界难以得到认同内的技能,记录下来.油...所有的钱,明天会更好.

  2. UVAlive 2519 Radar Installation (区间选点问题)

    Assume the coasting is an infinite straight line. Land is in one side of coasting, sea in the other. ...

  3. android视频库Vitamio

    之前尝试自己解码视频,然后播放显示,虽然音视频都可以播放,但是实现不了音视频的同步,所以使用第三方的视频库Vitamio来实现视频播放器功能,这样自己只需要实现播放解码的制作不不要关心底层解码和显示问 ...

  4. SQL_由创建表引出

    ***********************************************声明*************************************************** ...

  5. hdu3811(状态压缩dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3811 题目大意:给定1~N个数,求出至少满足一个条件的排列总数.M个条件如下:Ai位置的数为Bi 分析 ...

  6. 一步一步学android之事件篇——单选按钮监听事件

    在平常使用软件的时候,我们经常会碰见一些选择题,例如选择性别的时候,在男和女之间选,前面说过这个情况要用RadioGroup组件,那么点击了之后我们该怎么获取到选择的那个值呢,这就是今天要说的OnCh ...

  7. hdu 4740【模拟+深搜】.cpp

    题意: 给出老虎的起始点.方向和驴的起始点.方向.. 规定老虎和驴都不会走自己走过的方格,并且当没路走的时候,驴会右转,老虎会左转.. 当转了一次还没路走就会停下来.. 问他们有没有可能在某一格相遇. ...

  8. ConditonHelper

    在网上其实已经有很多类似这种拼接sql条件的类,但是没有看到一个让我感觉完全满意的这样的类.最近看到 http://www.cnblogs.com/xtdhb/p/3811956.html 这博客,觉 ...

  9. FragmentCustomAnimation实现Fragment的界面切换

    1.知识点:FragmentCustomAnimation 2.演示样例:来自于官网演示样例的简化,这样更方便于学习该知识点. 本演示样例的源代码下载地址为:http://download.csdn. ...

  10. 同步github工程gitcafe

    github固然好.仅仅是国内訪问有点慢. 为了提高博客訪问速度我决定把github上托管的博客同步到gitcafe上.最好能在DNS那里做CDN,可是貌似没有免费的服务.那直接指向gitcafe好了 ...