C/C++仿華容道小游戲
更新時(shí)間:2016年02月09日 19:09:37 作者:__lurenjia__
這篇文章主要介紹了C/C++仿華容道小游戲的相關(guān)資料,模仿實(shí)現(xiàn)華容道游戲,感興趣的朋友可以參考一下
本文實(shí)例介紹了C++模仿華容道小游戲?qū)崿F(xiàn)代碼,分享給大家供大家參考,具體內(nèi)容如下
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <stdbool.h>
#define maxnum 16
#define colnum 4
bool numexists(int *numbers, int length, int num);
int getnumber(int **numbers, int randIndex, int *length);
int* initnumbers(void);
void swap(int **a, int **b);
int main(int argc, char *argv[])
{
int *tempnumbers = initnumbers();
int *randnumbers = initnumbers();
int **numbers;
numbers = malloc(maxnum * sizeof(int*));
//bool a = numexists(numbers, 16, 3);
//printf("a=%d\n", a);
int length = maxnum;
srand((unsigned)time(NULL));
for (int i = 0; i < maxnum; i++)
{
int temp = getnumber(&tempnumbers, rand() % length, &length);
randnumbers[i] = temp;
numbers[temp] = &randnumbers[i];
//printf("%d%c", temp, (i + 1) % colnum == 0?'\n':'\t');
}
if (tempnumbers != NULL)
free(tempnumbers);
while (true)
{
system("clear");
for (int i = 0; i < maxnum; i++)
printf("%d%c", randnumbers[i], (i + 1) % colnum == 0?'\n':'\t');
printf("move number/ invalid num==exit: ");
int i;
if (!scanf("%d", &i))
{
printf("game over\n");
break;
}
if (i >= maxnum || i <0)
{
printf("sorry, i can't find %d\n", i);
break;
}
unsigned char sign = abs(numbers[i] - numbers[0]);
switch (sign)
{
case 1:
case 4: swap(&numbers[0], &numbers[i]); break;
}
}
if (numbers != NULL)
free(numbers);
if (randnumbers != NULL)
free(randnumbers);
}
void swap(int **a, int **b)
{
int *templocation = *a;
int tempvalue = **a;
**a = **b;
**b = tempvalue;
*a = *b;
*b = templocation;
}
int* initnumbers(void)
{
int *numbers = malloc(maxnum * sizeof(int));
for (int i = 0; i < maxnum; i++)
numbers[i] = i;
return numbers;
}
int getnumber(int **numbers, int randIndex, int *length)
{
int result = (*numbers)[randIndex];
(*numbers)[randIndex] = (*numbers)[--(*length)];
int *temp = realloc(*numbers, (*length) * sizeof(int));
*numbers = temp;
return result;
}
bool _numexists(int *numbers, int start, int end, int num)
{
printf("start: %d, end: %d, num: %d\n", start, end, num);
if (start == end)
return numbers[start] == num;
else
{
int middle = (start+end) / 2;
if (numbers[middle] == num)
return true;
else if (numbers[middle] > num)
return _numexists(numbers, start, middle-1, num);
else
return _numexists(numbers, middle+1, end, num);
}
}
bool numexists(int *numbers, int length, int num)
{
return _numexists(numbers, 0, length-1, num);
}
希望本文對(duì)大家學(xué)習(xí)C++程序設(shè)計(jì)有所幫助。
相關(guān)文章
C語(yǔ)言二維數(shù)組運(yùn)用實(shí)現(xiàn)掃雷游戲
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言二維數(shù)組運(yùn)用實(shí)現(xiàn)掃雷游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06
VC實(shí)現(xiàn)讓關(guān)閉按鈕成灰色不可用的方法
這篇文章主要介紹了VC實(shí)現(xiàn)讓關(guān)閉按鈕成灰色不可用的方法,比較實(shí)用的一個(gè)特殊功能,需要的朋友可以參考下2014-08-08
使用C語(yǔ)言實(shí)現(xiàn)CRC校驗(yàn)的方法
本篇文章是對(duì)使用C語(yǔ)言實(shí)現(xiàn)CRC校驗(yàn)的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
C語(yǔ)言如何利用輾轉(zhuǎn)相除法求最大公約數(shù)
這篇文章主要介紹了C語(yǔ)言如何利用輾轉(zhuǎn)相除法求最大公約數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
C語(yǔ)言運(yùn)用函數(shù)的遞歸實(shí)現(xiàn)漢諾塔
遞歸(recursive)函數(shù)是“自己調(diào)用自己”的函數(shù),無論是采用直接或間接調(diào)用方式。間接遞歸意味著函數(shù)調(diào)用另一個(gè)函數(shù)(然后可能又調(diào)用第三個(gè)函數(shù)等),最后又調(diào)用第一個(gè)函數(shù)。因?yàn)楹瘮?shù)不可以一直不停地調(diào)用自己,所以遞歸函數(shù)一定具備結(jié)束條件2022-07-07
C++ 智能指針使用不當(dāng)導(dǎo)致內(nèi)存泄漏問題解析
這篇文章主要介紹了C++ 智能指針使用不當(dāng)導(dǎo)致內(nèi)存泄漏問題解析,本文通過代碼示例給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-07-07

