当前位置:   article > 正文

双人五子棋(C++游戏)游戏代码在最底下_纯c++项目开发五子棋人对人版源代码

纯c++项目开发五子棋人对人版源代码

五子棋起源于中国,是全国智力运动会竞技项目之一,是一种两人对弈的纯策略型棋类游戏。双方分别使用黑白两色的棋子,下在棋盘直线与横线的交叉点上,先形成五子连珠者获胜。

五子棋容易上手,老少皆宜,而且趣味横生,引人入胜。它不仅能增强思维能力,提高智力,而且富含哲理,有助于修身养性。

称谓

五子棋,日文亦有连五子、五子连、串珠、五目、五目碰、五格、五石、五法、五联、京棋等多种称谓;英文则称之为FIR(Five In A Row的缩写)、Gomoku(日语“五目”的罗马拼音)、Gobang、connect 5、mo-rphion等;捷克文piskvorky,韩文omok等等。

许多国家的人对五子棋都有不同的爱称,例如,韩国人把五子棋称为“情侣棋”,表示情人之间下五子棋有利于增加情感的交流;欧洲人称其为“绅士棋”,代表下五子棋的君子风度胜似绅士;日本人则称其为“中老年棋”,说明五子棋适合中老年人的生理特点和思维方式。

历史沿革

发展

  • 日本

关于五子棋的起源,史料上并无明确记载。相传,在“尧造围棋”之前,五子棋就已经流行于民间。大约在南北朝时期,五子棋随围棋传入高丽(今朝鲜),后又传至日本。 [7] 

起初,五子棋主要在日本的皇宫贵族间流行,到元禄(1688—1703)末期已盛行于民间。明治3年(1899),《万朝报》经过公开征名,取意《汉书·律历志上》中“日月如合璧,五星如连珠”将五子棋正式命名为“连珠”。

  • 欧洲

20世纪初,传统五子棋及连珠从日本传入欧洲。五子棋英译为“Five In A Row”(缩写为FIR),汉语拼音“wǔ zǐ qí”,同时根据日语的罗马拼音,把“五目、五目碰”英译为“Gomoku、Gobang”,“连珠”英译为“Renju”。

1958年以及1979年,瑞典和前苏联分别成立了连珠联盟。1988年,日本、前苏联以及瑞典三个国家的连珠组织在瑞典成立国际连珠联盟(Renju International Federation,简称RIF)。

20世纪90年代欧洲一些国家给传统五子棋引入“交换”等规则后,经过发展逐渐形成一系列的Gomoku新规则。中欧一些国家成立了Gomoku组织,并和六子棋共同成立了国际联盟(GCIF)。

21世纪初,在举办世界连珠(renju)锦标赛的同时也举办了世界Gomoku锦标赛(GT)及六子棋国际公开赛(CT)。

2009年8月,在捷克共和国(Czech Republic)帕尔杜比采市(Pardubice)举行了第11届世界连珠锦标赛和第3届世界Gomoku锦标赛。

  • 中国

五子棋虽起源于中国,但长久以来五子棋在中国一直没有得到发展。

2001年,国家体育总局批准中国棋院试办全国性五子棋比赛(更准确地说,这里的“五子棋”应该被称为“连珠五子棋”或“连珠棋”)。

2002年8月2—4日,中国棋院举办了首届全国五子棋个人邀请赛,此后每年举办一次。

2003年,国家体育总局批准了中国棋院审定的《中国五子棋竞赛规则》(试行)和《中国五子棋段级位制》(试行)。

2006年2月,国家体育总局对五子棋正式立项,作为围棋下的一个二级项目。全国各地相继成立了新的五子棋俱乐部。

2007年5月和10月,中国棋院先后举办了首届全国五子棋团体锦标赛和首届全国五子棋个人锦标赛。

2008年6月和12月,中国棋院先后举办了第二届全国五子棋团体锦标赛和第二届全国五子棋个人锦标赛。

2009年5月和10月,中国棋院先后举办了第三届全国五子棋团体锦标赛和第三届全国五子棋个人锦标赛。

2009年11月,首届全国智力运动会将五子棋作为正式比赛项目 [1]  。

2010年6月14日,国家体育总局棋牌运动管理中心举办了全国五子棋公开赛。

2010年11月至2011年5月,中国移动首届全国棋牌网络争霸赛设有五子棋 [2]  。

2011年11月8日至18日,在湖北省武汉市举办了第二届全国智力运动会,五子棋增设女子团体项目,湖北籍棋手喜获双冠。 [4] 

2011年11月至2012年11月,全国网络智力运动会

2013年4月1日,正式启动第二届全国网络智力运动会。

2019年,中共海口市委宣传部、海南省五子棋运动协会承办了全国五子棋锦标赛,于10月3日上午在海南省海口市黄金海景大酒店正式开赛。比赛共吸引来自北京、河北、上海、浙江、河南、山东、江苏、安徽、四川、湖北、广东、海南12个省市148名选手。

2021年,国家体育总局棋牌中心、中国棋院、海南省体育总会主办,海南省五子棋运动协会承办全国五子棋锦标赛。 [5] 

针对先行必胜的改革

随着五子棋的发展,人们逐步发现先行优势非常大,最后得出“先行必胜”的结论。五子棋要成为竞技运动,核心问题是要解决传统五子棋下法中“先行必胜”的问题。

“竞技五子棋”就是参赛双方以棋盘和棋子为介体,进行智力性对抗的竞技体育项目

“交换”思维

“交换”思维有个形象的比喻:一个人切蛋糕,一个人选蛋糕。即:一人开局,另一人选择黑方还是白方。此方法最为公平、最有效率,且最为简洁实用。不过此方法使开局者不走已知的必胜,把棋艺的较量演化为对局者开局的博弈,而“必胜开局”依然存在。

如:欧洲的Swap2、Swap1;中国的Swap3、一手交换规则等。

禁手”思维

禁止以某种手段取胜。为了平衡先后手之间的差距,削弱先手优势,日本连珠提出“禁手”。后来连珠的发展证明禁手并不能平衡先后手之间的差距,依然是“先行必胜”。

“泡沫”原理

像泡沫一样会破灭。如“吃子”五子棋。连成5个后消失,同时拿掉对方一个棋子,自己再补一子。此原理的的特点是:把五子棋金球制改成了“进球制”,同时也最大效率地利用了棋盘和棋子,带来了全新的思维。问题是怎样计算胜负。

“井字游戏”原理

井字游戏又叫圈叉棋,圈叉棋是和棋,原因是空间很小。

通过缩小棋盘来抑制五子棋先行的优势。如:15路棋盘,13路棋盘等等。问题是多大的棋盘才能是和棋,知道和棋后还能成为竞技运动吗。

跷跷板”原理

五子棋始终是先行领先一子。如果双方轮流领先一子呢

台湾教授发明的六子棋,就如“跷跷板”一样。先行先下一子,然后双方轮流下两子,先连成6子者胜利。六子棋为第11届奥林匹亚计算机游戏程序竞赛项目,验证其公平性与复杂性。

“连珠棋”原理

禁手”思维+“交换”思维+“井字游戏”原理=连珠

如:RIF规则、Sakata规则、Yamaguchi规则Tarannikov规则等。

以上内容来自百度网盘

———————————————————————————————————————————

五子棋游戏的代码:

  1. #include<iostream>
  2. #include<conio.h>
  3. #include<Windows.h>
  4. using namespace std;
  5. int n[31][31];
  6. int a, b;
  7. bool gameover = false;
  8. int win = 0;
  9. int q;
  10. char er;
  11. void shuchu() {
  12. cout << " ";
  13. for(int z = 65; z <= q + 64; z++) {
  14. er = z;
  15. er = char(er);
  16. cout << er << " ";
  17. }
  18. cout << endl;
  19. for(int i = 1; i <= q; i++) {
  20. if(i <= 9) {
  21. cout << " "<< i;
  22. }
  23. if(i > 9) {
  24. cout << i;
  25. }
  26. for(int j = 1; j <= q; j++) {
  27. if(n[i][j] == 0) {
  28. if(i == 1 && j == 1) {
  29. cout << "┌";
  30. continue;
  31. }
  32. if(i == 1 && j == q) {
  33. cout << "┐";
  34. continue;
  35. }
  36. if(i == q && j == 1) {
  37. cout << "└";
  38. continue;
  39. }
  40. if(i == q && j == q) {
  41. cout << "┘";
  42. continue;
  43. }
  44. if(i == 1) {
  45. cout << "┬";
  46. continue;
  47. }
  48. if(i == q) {
  49. cout << "┴";
  50. continue;
  51. }
  52. if(j == 1) {
  53. cout << "├";
  54. continue;
  55. }
  56. if(j == q) {
  57. cout << "┤";
  58. continue;
  59. }
  60. cout << "┼";
  61. continue;
  62. }
  63. if(n[i][j] == 1) {
  64. cout << "○" ;
  65. continue;
  66. }
  67. if(n[i][j] == 2) {
  68. cout << "●";
  69. continue;
  70. }
  71. }
  72. cout << " " << i;
  73. cout << endl;
  74. }
  75. cout << " ";
  76. for(int z = 65; z <= q + 64; z++) {
  77. er = z;
  78. er = char(er);
  79. cout << er << " ";
  80. }
  81. cout << endl;
  82. }
  83. void doublep() {
  84. int y = 1;
  85. cout << "五子棋(双人游戏)A,B,C,D....各代表1,2,3,4...." <<endl;
  86. cout << "输入0,0离开游戏(双方均同意)" << endl;
  87. cout << "请选择棋盘大小:"<<endl;
  88. cout << "小(9*9)<S> 中(15*15)<M> 大(21*21)<B> 自定义(5-26)<Y>" << endl;
  89. char ss;
  90. cin >> ss;
  91. if(ss == 'S') {
  92. q = 9;
  93. }
  94. if(ss == 'M') {
  95. q = 15;
  96. }
  97. if(ss == 'B') {
  98. q = 21;
  99. }
  100. if(ss == 'Y') {
  101. cout << "请输入棋盘大小" << endl << "输入";
  102. cin >> q;
  103. if(q > 26 || q < 5) {
  104. cout << "你还皮???" << endl;
  105. return;
  106. }
  107. }
  108. if(ss != 'S' && ss != 'M' && ss != 'B' && ss != 'Y') {
  109. cout << "你还皮???";
  110. return;
  111. }
  112. cout << "你选择了"<< q << "乘" << q << "大小的棋盘" <<endl;
  113. cout << " ";
  114. for(int z = 65; z <= q + 64; z++) {
  115. er = z;
  116. er = char(er);
  117. cout << er << " ";
  118. }
  119. cout << endl;
  120. for(int i = 1; i <= q; i++) {
  121. if(i <= 9) {
  122. cout << " " << i;
  123. }
  124. if(i > 9) {
  125. cout << i;
  126. }
  127. for(int j = 1; j <= q; j++) {
  128. if(n[i][j] == 0) {
  129. if(i == 1 && j == 1) {
  130. cout << "┌";
  131. continue;
  132. }
  133. if(i == 1 && j == q) {
  134. cout << "┐";
  135. continue;
  136. }
  137. if(i == q && j == 1) {
  138. cout << "└";
  139. continue;
  140. }
  141. if(i == q && j == q) {
  142. cout << "┘";
  143. continue;
  144. }
  145. if(i == 1) {
  146. cout << "┬";
  147. continue;
  148. }
  149. if(i == q) {
  150. cout << "┴";
  151. continue;
  152. }
  153. if(j == 1) {
  154. cout << "├";
  155. continue;
  156. }
  157. if(j == q) {
  158. cout << "┤";
  159. continue;
  160. }
  161. cout << "┼";
  162. continue;
  163. }
  164. if(n[i][j] == 1) {
  165. cout << "○" ;
  166. continue;
  167. }
  168. if(n[i][j] == 2) {
  169. cout << "●";
  170. continue;
  171. }
  172. }
  173. cout << " " << i;
  174. cout << endl;
  175. }
  176. cout << " ";
  177. for(int z = 65; z <= q + 64; z++) {
  178. er = z;
  179. er = char(er);
  180. cout << er << " ";
  181. }
  182. cout << endl;
  183. while(gameover == false) {
  184. if(y % 2 == 1) {
  185. cout << "黑方下棋,输入放下棋子的坐标(横+竖),坐标均为数字" << endl;
  186. cin >> a >> b;
  187. if(a == 0 && b == 0) {
  188. cout << "请问白方是否同意?" << endl << "同意<Y> 不同意<其他字符>" << endl;
  189. char fg;
  190. cin >> fg;
  191. if(fg == 'Y') {
  192. cout << "Bye!" << endl;
  193. return;
  194. } else {
  195. cout << "白方不同意,请重新输入。" << endl;
  196. continue;
  197. }
  198. }
  199. if(a > q || b > q) {
  200. cout << "对不起,输出超限,请重新输入。" << endl;
  201. continue;
  202. }
  203. if(a < 1 || b < 1) {
  204. cout << "对不起,输出超限,请重新输入。" << endl;
  205. continue;
  206. }
  207. if(n[a][b] == 1 || n[a][b] == 2) {
  208. cout << "对不起,此格子已有棋子,请重新输入。" << endl;
  209. continue;
  210. }
  211. n[a][b] = 1;
  212. shuchu();
  213. }
  214. if(y % 2 == 0) {
  215. cout << "白方下棋,输入放下棋子的坐标(横+竖),坐标均为数字" << endl;
  216. cin >> a >> b;
  217. if(a == 0 && b == 0) {
  218. cout << "请问黑方是否同意?" << endl << "同意<Y> 不同意<其他字符>" << endl;
  219. char fg;
  220. cin >> fg;
  221. if(fg == 'Y') {
  222. cout << "Bye!" << endl;
  223. return;
  224. } else {
  225. cout << "黑方不同意,请重新输入。" << endl;
  226. continue;
  227. }
  228. }
  229. if(a > q || b > q) {
  230. cout << "对不起,输出超限,请重新输入。" << endl;
  231. continue;
  232. }
  233. if(a < 1 || b < 1) {
  234. cout << "对不起,输出超限,请重新输入。" << endl;
  235. continue;
  236. }
  237. if(n[a][b] == 1 || n[a][b] == 2) {
  238. cout << "对不起,此格子已有棋子,请重新输入。" << endl;
  239. continue;
  240. }
  241. n[a][b] = 2;
  242. shuchu();
  243. }
  244. if(y == q * q) {
  245. win = 3;
  246. gameover = true;
  247. }
  248. for(int i = 1; i <= q; i++) {
  249. for(int j = 1; j <= q; j++) {
  250. if(n[i][j] == 1 && n[i + 1][j] == 1 && n[i + 2][j] == 1 && n[i + 3][j] == 1 && n[i + 4][j] == 1) {
  251. win = 1;
  252. gameover = true;
  253. }
  254. if(n[i][j] == 2 && n[i + 1][j] == 2 && n[i + 2][j] == 2 && n[i + 3][j] == 2 && n[i + 4][j] == 2) {
  255. win = 2;
  256. gameover = true;
  257. }
  258. if(n[i][j] == 2 && n[i][j + 1] == 2 && n[i][j + 2] == 2 && n[i][j + 3] == 2 && n[i][j + 4] == 2) {
  259. win = 2;
  260. gameover = true;
  261. }
  262. if(n[i][j] == 1 && n[i][j + 1] == 1 && n[i][j + 2] == 1 && n[i][j + 3] == 1 && n[i][j + 4] == 1) {
  263. win = 1;
  264. gameover = true;
  265. }
  266. if(n[i][j] == 1 && n[i + 1][j + 1] == 1 && n[i + 2][j + 2] == 1 && n[i + 3][j + 3] == 1 && n[i + 4][j + 4] == 1) {
  267. win = 1;
  268. gameover = true;
  269. }
  270. if(n[i][j] == 2 && n[i + 1][j + 1] == 2 && n[i + 2][j + 2] == 2 && n[i + 3][j + 3] == 2 && n[i + 4][j + 4] == 2) {
  271. win = 2;
  272. gameover = true;
  273. }
  274. if(n[i][j] == 2 && n[i + 1][j + 1] == 2 && n[i + 2][j + 2] == 2 && n[i + 3][j + 3] == 2 && n[i + 4][j + 4] == 2) {
  275. win = 2;
  276. gameover = true;
  277. }
  278. if(n[i][j] == 2 && n[i - 1][j + 1] == 2 && n[i - 2][j + 2] == 2 && n[i - 3][j + 3] == 2 && n[i - 4][j + 4] == 2) {
  279. win = 2;
  280. gameover = true;
  281. }
  282. if(n[i][j] == 1 && n[i - 1][j + 1] == 1 && n[i - 2][j + 2] == 1 && n[i - 3][j + 3] == 1 && n[i - 4][j + 4] == 1) {
  283. win = 1;
  284. gameover = true;
  285. }
  286. }
  287. }
  288. y++;
  289. }
  290. if(win == 1) {
  291. cout << "恭喜黑方获胜!";
  292. return;
  293. }
  294. if(win == 2) {
  295. cout << "恭喜白方获胜!";
  296. return;
  297. }
  298. if(win == 3) {
  299. cout << "平局!";
  300. return;
  301. }
  302. }
  303. void singlep() {
  304. cout << "五子棋(单人游戏,与电脑对抗)A,B,C各代表10,11,12" <<endl;
  305. cout << "输入0,0离开游戏" << endl;
  306. cout << " 1 2 3 4 5 6 7 8 9 A B C " << endl;
  307. for(int i = 1; i <= 12; i++) {
  308. if(i <= 9) {
  309. cout << i << " ";
  310. }
  311. if(i > 9) {
  312. cout << i;
  313. }
  314. for(int j = 1; j <= 12; j++) {
  315. n[i][j] = 0;
  316. if(n[i][j] == 0) {
  317. if(i == 1 && j == 1) {
  318. cout << "┌";
  319. continue;
  320. }
  321. if(i == 1 && j == 12) {
  322. cout << "┐";
  323. continue;
  324. }
  325. if(i == 12 && j == 1) {
  326. cout << "└";
  327. continue;
  328. }
  329. if(i == 12 && j == 12) {
  330. cout << "┘";
  331. continue;
  332. }
  333. if(i == 1) {
  334. cout << "┬";
  335. continue;
  336. }
  337. if(i == 12) {
  338. cout << "┴";
  339. continue;
  340. }
  341. if(j == 1) {
  342. cout << "├";
  343. continue;
  344. }
  345. if(j == 12) {
  346. cout << "┤";
  347. continue;
  348. }
  349. cout << "┼";
  350. continue;
  351. }
  352. if(n[i][j] == 1) {
  353. cout << "○" ;
  354. continue;
  355. }
  356. if(n[i][j] == 2) {
  357. cout << "●";
  358. continue;
  359. }
  360. }
  361. cout << endl;
  362. }
  363. while(gameover == false) {
  364. cout << "你是黑方";
  365. }
  366. }
  367. int main() {
  368. char tu;
  369. cout << "五子棋~~" << endl;
  370. cout << "双人模式" << endl;
  371. cout << "输入任意键开始游戏";
  372. getch();
  373. system("cls");
  374. doublep();
  375. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/336429
推荐阅读
相关标签
  

闽ICP备14008679号