贪吃蛇C语言代码实现(难度可选)

2025-05-27 0 57

本文实例为大家分享了C语言实现贪吃蛇的具体代码,供大家参考,具体内容如下

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

178

179

180

181

182

183

184

185

186

187

188

189

190

191

192

193

194

195

196

197

198

199

200

201

202

203

204

205

206

207

208

209

210

211

212

213

214
/*********************************************************

********************贪吃蛇(难度可选)********************

**************制作者:Xu Lizi 日期:2012/12/31********

********************部分函数有借鉴************************

**********************************************************/

#include<stdio.h>

#include<conio.h>

#include<string.h>

#include<stdlib.h>

#include<time.h>

int snakey[100]={5,4,3,2,1}; /*定义蛇的横坐标*/

int snakex[100]={1,1,1,1,1}; /*定义蛇的纵坐标,蛇头起始位置为(5,1)*/

int life=0; /*定义蛇的生命,0表示存活,1表示死亡*/

int lenght=5; /*定义蛇的长度,初始为5节*/

char map[12][24]={"***********************", /*y*/

"* *",

"* *",

"* *",

"* *",

"* *",

"* *",

"* *",

"* *",

"* *",

"* *",

/*x*/ "***********************"};

void put_money(int i,int j) /*放钱函数,使用随机数,随机出现食物*/

{

int x=0,y=0;

srand(time(NULL));

while ( (map[y][x]==003) || (map[y][x]==002) || (map[y][x]=='*') || ((x==i)&&(y==j)) )

{

x=rand()%21+1;

y=rand()%10+1;

}

map[y][x]='$';

return;

}

void output() /*输出*/

{

system("cls");

int i,j;

for(i=0; i<12; i++)

{

for(j=0; j<23; j++) printf("%c", map[i][j]);

printf("\\n");

}

return;

}

void gameover() /*游戏结束*/

{

life=1;

printf("笨蛋,输了吧!!!\\n");

return;

}

void turn_up() /*向上移动*/

{

system("cls");

int i;

if ( (snakex[0]==1) || (map[snakex[0]-1][snakey[0]]==003) ) gameover(); else {

if (map[snakex[0]-1][snakey[0]]=='$')

{

put_money( snakey[0], snakex[0]-1 );

lenght++;

map[snakex[lenght-1]][snakey[lenght-1]]=003;

}

for(i=lenght; i>0; i--)

{

snakex[i]=snakex[i-1];

snakey[i]=snakey[i-1];

}

map[snakex[lenght]][snakey[lenght]]=' ';

snakex[0]--;

for(i=lenght-1; i>0; i--) map[snakex[i]][snakey[i]]=003;

map[snakex[0]][snakey[0]]=002;

output();

}

return;

}

void turn_down() /*向下*/

{

system("cls");

int i;

if ( (snakex[0]==10) || (map[snakex[0]+1][snakey[0]]==003) ) gameover();else {

if (map[snakex[0]+1][snakey[0]]=='$')

{

put_money(snakey[0],snakex[0]+1);

lenght++;

map[snakex[lenght-1]][snakey[lenght-1]]=003;

}

for(i=lenght; i>0; i--)

{

snakex[i]=snakex[i-1];

snakey[i]=snakey[i-1];

}

snakex[0]++;

map[snakex[lenght]][snakey[lenght]]=' ';

for(i=lenght-1; i>0; i--) map[snakex[i]][snakey[i]]=003;

map[snakex[0]][snakey[0]]=002;

output();

}

return;

}

void turn_left() /*向左*/

{

system("cls");

int i;

if ( (snakey[0]==1) || (map[snakex[0]][snakey[0]-1]==003) ) gameover();else {

if (map[snakex[0]][snakey[0]-1]=='$')

{

put_money(snakey[0]-1,snakex[0]);

lenght++;

map[snakex[lenght-1]][snakey[lenght-1]]=003;

}

for(i=lenght; i>0; i--)

{

snakex[i]=snakex[i-1];

snakey[i]=snakey[i-1];

}

map[snakex[lenght]][snakey[lenght]]=' ';

snakey[0]--;

for(i=lenght-1; i>0; i--) map[snakex[i]][snakey[i]]=003;

map[snakex[0]][snakey[0]]=002;

output();

}

return;

}

void turn_right() /*向右*/

{

system("cls");

int i;

if ( (snakey[0]==21) || (map[snakex[0]][snakey[0]+1]==003) ) gameover();else {

if (map[snakex[0]][snakey[0]+1]=='$')

{

put_money(snakey[0]+1,snakex[0]);

lenght++;

map[snakex[lenght-1]][snakey[lenght-1]]=003;

}

for(i=lenght; i>0; i--)

{

snakex[i]=snakex[i-1];

snakey[i]=snakey[i-1];

}

map[snakex[lenght]][snakey[lenght]]=' ';

snakey[0]++;

for(i=lenght-1; i>0; i--) map[snakex[i]][snakey[i]]=003;

map[snakex[0]][snakey[0]]=002;

output();

}

return;

}

int main()

{

int i,timeover,hard;

long start;

char name , direcation;

printf("\\n 向上移动:W ;向下移动:S ; 向左移动:A ; 向右移动:D \\n");

printf("\\t请选择难度(数字)\\n\\t分1~5级,分别代表\\n\\t1难,2中上,3中,4中下5,易:\\n");

scanf("%d",&hard);

system("cls");

for(i=1;i<5;i++) map[1][i]=003; /*输出蛇身*/

map[1][5]=002; /*输出蛇头*/

put_money(0,0);

output();

while(life!=1) /*当蛇死亡时结束循环*/

{

/*让蛇自动运行的函数******有借鉴*/

timeover=1;

start=clock();

while((timeover=(clock()-start<=hard*100))&&!kbhit()); //难度设定

if(timeover)

{

direcation=getch();

}

/*让蛇自动运行的函数******有借鉴*/

switch(direcation)

{

case 'w':turn_up();break;

case 's':turn_down();break;

case 'a':turn_left();break;

case 'd':turn_right();break;

}

}

return 0;

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持快网idc。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 贪吃蛇C语言代码实现(难度可选) https://www.kuaiidc.com/73087.html

相关文章

发表评论
暂无评论