c语言之贪吃蛇游戏,为什么最后运行时没有苹果出现?求助大神!!!

/* c语言之贪吃蛇 */

#include
#include
#include
#include
#include
#include

#define N 21
int apple[3]; //食物
char score[3]; //分数
char tail [3];//蛇尾前面一节

//输出坐标
void gotoxy(int x,int y)
{
COORD pos;
pos.X=x;
pos.Y=y;
SetConsoleCursorPosition(GetStdHandle(STD_OUTPUT_HANDLE),pos); //定义一个结构体pos,x,y就是构成的成员

}

// 判断出界
int Block(char head[2])
{
if((head[0]N)||(head[1]N))
return 1;
return 0;
}
//颜色函数
void color(int b)
{
HANDLE hConsole =GetStdHandle((STD_OUTPUT_HANDLE));
SetConsoleTextAttribute(hConsole,b);//调用API设置字体和背景的颜色函数
}

//界面初始化
void init(char plate[N+2][N+2],char ***snake_x,int len)
{
int i,j;
char **snake=NULL;
*len=3;
score[0]=score[3]=3;
snake =(char *
)realloc(snake,sizeof(char )(*len));
for(i=0;i<*len;i++)
snake[i]=(char *)malloc(sizeof(char)*2);
for(i=0;i<3;++i)
{
snake[i][0]=N/2+1;
snake[i][1]=N/2+1+i;

}
for(i=1;i<=N;++i)
for(j=1;j<=N;++j)
    plate[i][j]=1;
apple[0]=read()%N+1;
apple[1]=read()%N+1;
apple[2]= 1;
  for(i=0;i<N+2;++i)
     {
        gotoxy(0,i);
        for(j=0;j<N+2;++j)
        {
            switch(plate[i][j])
            {

            case 0:
                color(12); 
                printf("□");
                   color (11);
                continue;
            case 1:
                color(11);
                 printf("■");
                 continue;
            default:;

             }
         }
printf("\n");

}
for(i=0;i<(*len);++i)
{
gotoxy(snake[i][1]*2,snake[i][0]);
printf("★");
}
printf("\n");
*snake_x=snake;
}
void Manual()
{
gotoxy(N+30,2);
color(10);
printf("按W,D,S,A移动方向");
gotoxy(N+30,4);
printf("按SPACE暂停");
gotoxy(N+30,8);
color(11);
printf("历史最高分为:");
color(12);
gotoxy(N+44,8);
printf("%d",score[1]*10);
color(11);
gotoxy(N+30,12);
printf("你当前的得分为:0");
}
//键盘控制
char **Move(char **snake,char dirx,int *len)
{
int i,full=Eat(snake[0]);
memcpy(tail,snake[(*len)-1],2);
for(i=(*len)-1;i>0;--i )
memcpy(snake[i],snake[i-1],2);
switch(dirx)
{
case'w':
case'W':
--snake[0][0];
break;
case'a':
case'A':
--snake[0][1];
break;
case's':
case'S':
++snake[0][0];
break;
case'd':
case'D':
++snake[0][1];
break;
default:;

    }
    if(full)
    {
        snake=(char **)realloc(snake,sizeof(char*)*((*len)+1));
        snake[(*len)]=(char*)malloc(sizeof(char)*2);
        memcpy(snake[(*len)],tail,2);
        ++(*len);
        ++score[0];
        if(score[3]<16)
               ++score[3];
         tail[2]=1; 

    }
    else 
      tail[2]=0;
    return snake;

}

//取记录积分
int File_in()
{
FILE *fp;
if((fp=fopen("C:\tcs.txt","a+"))!=NULL)
{
gotoxy(N+18,N+2);
printf("文件不能打开\n");
exit(0);
}
if((score[1]=fgetc(fp))!=EOF)
;
else
score[1]=0;
return 0;

}

//存数据
int File_out()
{
FILE *fp;
if(score[1]>score[0])
{
gotoxy(10,10);
color(12);
printf("闯关失败 加油吧 骚年");
gotoxy(0,N+2);
return 0;
}
if((fp=fopen("C:\tcs.txt","w+"))==NULL)
{
printf("文件不能打开\n");
exit(0);
}
if(fputc(--score[0],fp)==EOF)
printf("输出失败\n");
gotoxy(10,10);
color(12);
puts("骚年不错哟");
gotoxy(0,N+2);
return 0;
}

//释放空间
void Free(char**snake,int len)
{
int i;
for(i=0;i<len;i++)
free(snake[i]);
free(snake);
}

//吃食物
int Eat(char snake[2])
{
if((snake[0]==apple[0])&&(snake[1]==apple[1]))
{
apple[0]=apple[1]=apple[2]=0;
gotoxy(N+44,10);
color(13);
printf("%d",score[0]*10);
color(11);

    return 1;

}
    return 0;

}

//蛇移动
void Draw(char **snake,int len)
{
if(apple[2])
{
gotoxy(apple[1]*2,apple[0]);
color(12);
printf("●");
color(11);

}
gotoxy(tail[1]*2,tail[0]);
if(tail[2])
{
color(14);
printf("★");
color(11);
}
else
printf("■");
gotoxy(snake[0][1]*2,snake[0][0]);
color(14);
printf("★");
color(11);
printf("\n");

}

int main(int argc, char *argv[])
{
int len;
char ch='g';
char a[N+2][N+2]={{0}};
char **snake;
srand((unsigned)time(NULL));
color(11);
File_in();
init(a, &snake, &len);
Manual();

while(ch!=0X1B) //按esc键结束
{
Draw(snake,len);
if(!apple[2])
{
apple[0]=read()%N+1;
apple[1]=read()%N+1;
apple[2]=1;
}
Sleep(200-score[3]*10);
setbuf(stdin,NULL);
if(kbhit())
{
gotoxy(0,N+2);
ch=getche();
}
snake=Move(snake,ch,&len);
if(Block(snake[0])==1)
{
gotoxy(N+2,N+2);
printf("你输了");
File_out();
Free(snake,len);
getche();
return 1;

      }

 } 
 Free(snake,len);
return 0;

}

4个回答

把开始那几个#include的代码补上,贴一下

#include
#include
#include
#include
#include
#include

�PNG


IHDR � � ���� IDATx����O��Ɵ���=�p�E�-^������A���>�da��D�G���d)X��"�OC"�������1V@��82␅� � y��|���/�=COυ����Y#<}�����޷���
}�͍�/���W�^�f�����g�;<���j��0��D���Ig�رcY�-.{g��:�e8�
|*���:^��x��N��蕯��sp���˘��S�~�������?Ey�\����q��8f�}�Q��&���/�mu�|?�Օ�k����q��:6<��S��]�����t xO�}3�o)��KZ=��˟�LV O���&&GZ�
XO~�Q�C�p�߇Cf��yǧ"�%?I�]��qUp��O�[��>.�����KP2��^��/*פ�����4�k������.����,O)�3 ��LG��V^����t �=/��a�2��v qM��?�4넀�De�(����*���}�iJ���@=�@�;MJ(�b�?���&�������}�{ �h�k�&w���Uq��s��M�r���y?]�6o���2�χ�<���)��У���X��4Cf�a���]��?qBTJ)�ˮt�p;2��Ϣ��{���,�j����g�4^B��Y_ԳQ�;e����V'�C�?�a�Zeu)E%�9d�G\�g��HQ
W�̼y��4����>ܟg�dE"x�~�C��?�g9�ʧa}���G��N�-q��u��H+�Q�<wE�pXX�=Q�ϸ\K�V��4�c ��'��l�uYU)lY�ߴ�q�<?��e'���Y�2�^!���\T�[yT��"[CYIr g
����2>t��^��G?*� q��DO��f����l���.~���FfO�qI���4��;
��m��|����E��<����{�7�#���{aW��cm��g=�Z!NX-h��)~�����Ɏ�ӑ��v��F���L�Z}YQ��X[9�$�s�.ws"Ok�u7��K��煘V~;�?i����%�.�mI�,�taWV�3a���<ˁ������r�ԗ��̢*�([Q٩η�
q�F�#j~ ��������K��I�'���~�e��� s�CDr0e(wEqc[n��
���e��ҹ�9M�!3��.���6�g6d����2���=���D!�LѨi?���a��A=��%���u&f���LYYwd_P���z7}�}�m6���կ�)dty|§?�
w?M>z�tҗ*e�k}������k
�X���[�֞)H)�ב���
��rS=S4j*D��S����
%�ο#-�tCSVc��pa�� �_�{�� ����u�=s ��A�'��-��Z�i?�7����9�8��-��f�Pb����q=�9�0���*{�Ɲ����<��J���\S{�O3�=X���|9���oQt�_wFV�Ha�U���w=;������g���(lW�NS�G�#ׄ��E�� o&��^���h�j~�|�1R��"�YH�̚���YCr����iC���,")M=������ !�B$D(DB4@�wg�#l|�0��$�h�!�bf�1ƒI$�gs��H����]q��74�e(<fGR(�#�&��
/���F���}��A�x3���!�n�Y�ݙ.��!D�5$U�!J���"$D�wg0"_߆��a�Y�y&!G������XI�~YBtF��)!�B$D(DB4�B$D(DB4�B$D�q5�<?d!���5C�E���isC�HU�H��mߦk�z������}Q$D�m߆{:���8ՔT3�]��^"�;���Q���ջXh�);���Q

有随机数的取值吗?没看见srand函数啊

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
C语言之贪吃蛇 经典收藏)——
C语言之贪吃蛇蛇 希望对大家学习有所帮助
C语言之实现贪吃蛇
#include #include #include #include #define MAX_WIDE 50 #define MAX_HIGH 16 short dx=1,dy=0,randxy,score=0; COORD coord;//记录坐标 struct Snake { short len;//身体长度 short body[MAX_WIDE*MAX_HIG
C语言之小游戏(推箱子,贪吃蛇)
推箱子 基本思路: 绘制一个地图,包含人,箱子,墙,目的地; 2.实现人的移动; 3.实现人和箱子同时移动。 代码: #include&lt;graphics.h&gt; //使用EGE图形库 #include&lt;stdio.h&gt; #include&lt;windows.h&gt; #include&lt;time.h&gt; #define MAPSIZE 10 int map...
C语言之推箱子游戏代码
每天学习一点点,每天容易一点点。一个简单的C语言程序,用来复习c语言,代码通俗易懂。有什么问题望各位不吝赐教。/******************************************* 用最简单的C语言语句写个推箱子的程序。 ********************************************/ #include <stdio.h> #include <coni
C语言之选择排序
选择法排序是相对好理解的排序算法。假设要对含有n个数的序列进行升序排列,算法步骤是: 1、从数组存放的n个数中找出最小数的下标(算法见下面的“求最值”),然后将最小数与第1个数交换位置; 2、除第1个数以外,再从其余n-1个数中找出最小数(即n个数中的次小数)的下标,将此数与第2个数交换位置; 3、重复步骤1 n-1趟,即可完成所求。 好了,接下来...
C语言之位运算
神奇的位操作
C语言之函数指针
函数指针 数组在函数中当参数传递给另一个数组进行操作时,它操作的还是原数组,原因是:如果传入的数组很大,而如果要开辟新的内存去装数组,那就对内存的占用就有点太浪费了,如果数组非常之大那就不好说了。所以数组的传递都是原数组内部的元素直接变动。   对于二位数组,指针的用法又是不同:   int a[3][4];   int (*p)[4];   //*p指向的是数组的行元素的首地址    
C语言之递归函数
C语言之递归函数 递归定义 尾递归 一般递归 递归定义C语言中的递归定义为函数自己调用自己,函数递归有时可以比较方便的完成某些任务,比如可以替代循环等。 C语言中的函数递归在递归语句前的所有语句会顺序执行,在递归语句后的return或者函数末尾前的所有语句会逆序执行。 递归必须要有递归结束条件,否则递归会一直进行下去,成为死循环。 //recursion.c-----演示递归调用 #include
C语言之断言
我们在使用C语言编写工程代码时,我们总会对某种假设条件进行检查,断言就是用于在代码中捕捉这些假设,可以将断言看作是异常处理的一种高级形式。断言表示为一些布尔表达式,程序员相信在程序中的某个特定点该表达式值为真。可以在任何时候启用和禁用断言验证,因此可以在测试时启用断言,而在部署时禁用断言。同样,程序投入运行后,最终用户在遇到问题时可以重新起用断言。它可以快速发现并定位软件问题,同时对系统错误进行自
C语言之mystrcat
#include char *mystrcat(char *str1,char *str2) {  char *p = str1;  while(*str1)  str1++;  while(*str2)  {   *str1++ = *str2++;  }   *str1 = '\0';      return p; }   int main() {  char
C语言之括号匹配
括号匹配简单实用,尤其在编译器处理程序格式(括号是否匹配)问题上发挥突出作用。
C语言之四书五经
C语言之四书五经:C程序设计语言,C和指针,C专家编程,C陷阱与缺陷。每一个学习C/C++的编程员都不应该错过的经典教程!
C语言之杨辉三角
#includernmain()rnrn long i,j,n,k;rn scanf("%ld",&n);rn for(i=1;i<=n;i++)rn rn k=1;rn for(j=1;j
C语言之编译过程
返回值0代表成功,其它返回值均为返回异常状态。 #define 、#include 等在预处理阶段处理,而在编译时已经不存在了,所以它们不是关键字 #include “math.h” 仅在当前路径查找math.h文件 #include &amp;lt;math.h&amp;gt; 在系统环境变量值查找此文件 #define 宏名 宏体(为安全起见,加括号) eg:#define ABC 5+3 pri...
C语言之指针
函数: int (*p) (int a,int,b) //定义了 P是一个 指向函数的指针变量 前面一个int是指函数返回值的类型 int * p(int a,int,b) // 定义了一个P函数,该函数的返回值为一个整型指针变量 (因为() 的优先级高于*) int *a[10]:数组指针。数组a里存放的是10个int型指针 int (*a)[10]:a是指针,指...
C语言之预处理
文章目录预处理定义 预处理定义 程序设计领域中,预处理一般是指在程序源代码被翻译为目标代码的过程中,生成二进制代码之前的过程。典型地,由预处理器(preprocessor) 对程序源代码文本进行处理,得到的结果再由编译器核心进一步编译。这个过程并不对程序的源代码进行解析,但它把源代码分割或处理成为特定的单位——(用C/C++的术语来说是)预处理记号(preprocessing token)用来支持...
C语言之判断
新学的知识 近三天的进度是学习到了C语言的循环,初步了解了while,do_while和for,距离掌握以至于熟练运用,还需要一些时间去消化所学的知识。 现阶段主要掌握的知识还处于判断阶段,对于判断的知识自己感觉掌握的不错,下面是自己写的关于BJT与UTC转化的代码: #include&amp;lt;stdio.h&amp;gt; int main() { int BJT; scanf(&quot;...
c语言之数组
1.c语言不允许对数组进行动态定义。int a[k];这样是错的,但是可以用#define 进行宏定义 #define 4 k   2. 可以给一部分元素进行赋值,例如,int a[10] = {0,1,2,3};这样是表示给前四个元素赋值,后面的数值自动给0;  3.int a[3][4];是三行四列;  4. 二维数组也可以只对部分元素赋值。int a[3][4] = {{1},{1,2
C语言之数组名
我们知道数组名实际上是一个指针. 问题的关键是数组名指向的内容是什么. 对于一维数组来说, 数组名是指向数组第一个元素的内存空间的指针常量. 比如: int array[10]; 数组名array代表的就是array[0]的地址. array+1 代表的是array[1]的地址, 也就是说 array的步进间隔为一个int变量所占的内存空间. 对于二维数组来说, 数组名是指向数组第一维元素的...
C语言之排序
1.冒泡法 void bublesort(int data[],int n) { int i,j,temp; for(i=0;i&lt;n-1;i++) { for(j=0;j&lt;n-i-1;j++) { if(data[j]&gt;data[j+1]) { temp = data[j]; ...
C语言之折半查找
//折半查找 #include &quot;stdio.h&quot; int find(int num,int arr[]) { int xiabiao=-1; int low=0; int high=8; int mid=(low+high)/2; while(low&amp;lt;=high) { if(num==arr[mid]) { xiabiao=mid; ...
C语言之插入排序
有一个已经有序的数据序列,要求在这个已经排好的数据序列中插入一个数,但要求插入后此数据序列仍然有序,这个时候就要用到一种新的排序方法——插入排序法,插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据,算法适用于少量数据的排序,时间复杂度为O(n^2)。是稳定的排序方法。 插入过程如下图所示: 以下为C语言代码实现用的编译器为GCC: #
c语言之单链表
1.什么是链式存储结构?
C语言之文件读写
文本文件与二进制文件的区别“\r\n”的知识文件结束符常用函数 文本文件:以字符为单位(ASCII码)存储,途中经过转化。例如int型变量 num = 1234。以文本形式写入时,先将num转换为“1”“2”“3”“4”对应的ascii码,再写入文本。读取时,经过反变换,将“1”“2”“3”“4”转化为int型。 二进制文件:直接以二进制形式存储。例如int num = 1234,二进制形式为
C语言之字符串
C语言之字符串 字符串定义 字符串的输入输出 字符串函数 字符串杂项 字符串定义 字面量定义 字符串数组定义 字符串指针定义 字面量定义 字符串的字面量定义也就是常说的字符串常量定义,形如以下形式: “hello c string&quot; 上面的字符串就成为字符串的常量定义,这个字符串自身就是一个地址,只不过是一个匿名地址,可以像使用数组或指针那样使用这个字面量。比如使用*(“hello c stri
C语言之递归
一,什么是递归? 递归是一种函数的一种使用方式! 当函数调用自身时,我们就称为“递归”。 二,从实例中理解递归 1,年龄推算问题 有 5 个人坐在一起,问第 5 个人多少岁?他说比第 4 个人大 2 岁。问第 4 个人岁 数,他说比第 3 个人大 3 岁。问第 3 个人,又说比第 2 个人大 2 岁。问第 2 个人,又说比第 1 个人大 2 岁。最后问第 1 个人,他说是 10...
C语言之数组
内存中的数组  数组在内存中所占的空间是连续的,其中数组名可以看作是数组首元素的地址。 一维数组(int a[5])  a:数组首元素的地址   a+1:指向下一个元素(a[1])  &a:数组的地址   &a+1:跳过一个该数组在内存中的所占的大小,指向该数组接下来的一个地址 二维数组(int a[5][5])  a:首行地址   a+1:指向下一行  &a:数组的地址  
C语言之输入输出函数
I/O函数的三种方式:单个字符,文本行,二进制数据 单个字符 输入函数: int getchar( void ); 从标准输入里读取下一个字符,相当于getc(stdin)。返回类型为int型,为用户输入的ASCII码,出错返回-1。 int getc( FILE *stream ); 和getchar功能一样,从指定的文件流中读取一个字符,读取后文件指针不会移动 getc(st...
c语言之自定义类型
union enum struct 结构体内存对齐
C语言之字符串操作
1.字符串的复制 char *Mystrcpy(const char *source, char *target, int n) { int i = 0; while(source[i] != '\0') i++; if(i &amp;lt;= n) { i = 0; while(source[i] != '\0') ...
C语言之逻辑运算符
1.逻辑运算符分析1.1程序中的短路-||从左向右开始计算    ·当遇到为真的条件时停止计算,整个表达式为真    ·当所有条件为假时表达式才为假-&amp;amp;&amp;amp;从左向右开始计算:    ·当遇到为假的条件时停止计算,整个表达式为假    ·当所有条件为真时表达式才为真1.2逻辑表达式中,&amp;amp;&amp;amp;比||具有更高的优先级2.!究竟是什么?小结在程序中的逻辑表达式遵从短路规则在&amp;a...
C语言之位域
C语言 位域
C语言之常用
本篇博文最后修改时间:2017年08月04日 22:10。 一、简介 C语言常用。 二、实验平台 电脑平台:Windows7 64位旗舰 编译软件:VC6.0++ 三、版权声明 博主:_懵懂 声明:此博客仅供参考不做任何商业用途,最终解释权归原博主所有。 原文地址:http://blog.csdn.NET/qq_18842031 ...
C语言之链表
写在前边 C语言链表是一种很常见的数据结构,熟练掌握链表对理解和运用C语言有着很大的作用。在其他的博客中很容易搜到链表的相关操作。在这里就不在赘述了。 github上链接:https://github.com/myzcl/C-pratice 里面还有很多c语言的练习。 代码 下面是头结点的链表示例。 #include &amp;amp;lt;stdio.h&amp;amp;gt; #include &amp;amp;lt;stdlib.h&amp;amp;gt...
C语言之斐波那契数列
C语言之斐波那契数列,1,1,2,3,5……编写程序求第十项。 #include&amp;amp;lt;stdio.h&amp;amp;gt; int pheponatch(int N) { int a[N]; int i=1,j=2,k=N,q; a[i] = 1; a[j] = 1; printf(&amp;quot;%-6d&amp;quot;,a[i]); printf(&amp;quot;%-6d&amp;quot;,a[j])
C语言之哈希表
写在前面:项目中用一张哈希表来存储设备的属性等信息,用到了哈希表这块,因为对哈希表用的并不是太多,认识没有那么深刻,所以,这里花时间对哈希总结以及写代码调试了一下,加深点印象。 正文: 1、哈希表的作用:为了根据数据部分的关键内容,计算出对应节点完整数据的内存地址。如果用链表的话,链表如果长度很长,就会需要花费较多的时间来遍历链表。为了解决效率问题,哈希表应运而生。 2、哈希表的排布状况,画...
C语言之地址
可以说指针是C语言的灵魂,个人觉得早些接触还是比较好的,所以把数组和一些小的知识点放在后边。当初我们的老师讲C语言的时候,指针竟然用了几分钟就略过了,以致于后来我听别人提到指针都有一种神秘感,觉得好难,当我自己真的学到了指针的时候,并没有觉得有多难,反而觉得指针真好用,这应该算是C语言的神秘之处了吧。因为指针是指向一个地址的,因此先介绍地址。什么是地址?在32位的编译环境下,地址是由8个16进制的...
C语言之线性表
文章目录什么是线性表线性表的表现形式线性表的常见操作在顺序表的任何一个地方插入数据在顺序表中任意位置删除要给节点得到整个顺序表的大小将线性表重置为空表销毁顺序线性表判断是否为空表代码测试 什么是线性表 线性表,也叫做顺序表。类似链表,但是里面的数据存储空间是连续的,不像链表是片段的,不连续。 顺序存储,数据连续的存储,中间不能有空值。 如果需要插入数据,在插入的位置之后的数据需要一个一个的往...
c语言之运算符
关于c语言中的运算符的简要介绍和说明
C语言之输入输出
文章说明:本博客是在考研之后复习C语言的,之前有一些基础,是用作单片机编程用的,但无奈不够综合和全面,很是惭愧,两次计算机二级都没有过,实在是有损校师之名。今天是系统的从头至尾总结一下。古人云,温故而知新,可以为师矣。本人深知才疏学浅,不想自我安慰,只想自我提高罢了。 现C语言第一贴。(教材自选,软件为经典的C++6.0) /*This is the first C program*/ #inc
相关热词 c++和c#哪个就业率高 c# 批量动态创建控件 c# 模块和程序集的区别 c# gmap 截图 c# 验证码图片生成类 c# 再次尝试 连接失败 c#开发编写规范 c# 压缩图片好麻烦 c#计算数组中的平均值 c#获取路由参数