导航:首页 > 编程语言 > 一个简单游戏的编程

一个简单游戏的编程

发布时间:2024-04-02 10:43:01

A. 姹傚嚑C璇瑷涓灏忔父鎴忎唬镰侊纴绠鍗旷殑锛岃佹敞閲娿併佽阿璋浜嗐

// Calcu24.cpp : Defines the entry point for the console application.
//
/*
6-6
24镣规父鎴
*/
#include "conio.h"
#include "stdlib.h"
#include "time.h"
#include "math.h"
#include "string.h"/*
浠庝竴鍓镓戝厠鐗屼腑锛屼换鍙4寮犮
2-10 鎸夊叾镣规暟璁$畻(涓轰简琛ㄧず鏂逛究10鐢═琛ㄧず)锛孞,Q,K,A 缁熶竴鎸 1 璁$畻
瑕佹眰阃氲繃锷犲噺涔橀櫎锲涘垯杩愮畻寰楀埌鏁板瓧 24銆
链绋嫔簭鍙浠ラ殢链烘娊鍙栫焊鐗岋纴骞剁敤璇曟帰娉曟眰瑙c
*/void GivePuzzle(char* buf)
{
char card[] = {'A','2','3','4','5','6','7','8','9','T','J','Q','K'}; for(int i=0; i<4; i++){
buf[i] = card[rand() % 13];
}
}
void shuffle(char * buf)
{
for(int i=0; i<5; i++){
int k = rand() % 4;
char t = buf[k];
buf[k] = buf[0];
buf[0] = t;
}
}
int GetCardValue(int c)
{
if(c=='T') return 10;
if(c>='0' && c<='9') return c - '0';
return 1;
}
char GetOper(int n)
{
switch(n)
{
case 0:
return '+';
case 1:
return '-';
case 2:
return '*';
case 3:
return '/';
} return ' ';
}double MyCalcu(double op1, double op2, int oper)
{
switch(oper)
{
case 0:
return op1 + op2;
case 1:
return op1 - op2;
case 2:
return op1 * op2;
case 3:
if(fabs(op2)>0.0001)
return op1 / op2;
else
return 100000;
} return 0;
}
void MakeAnswer(char* answer, int type, char* question, int* oper)
{
char p[4][3];
for(int i=0; i<4; i++)
{
if( question[i] == 'T' )
strcpy(p[i], "10");
else
sprintf(p[i], "%c", question[i]);
}

switch(type)
{
case 0:
sprintf(answer, "%s %c (%s %c (%s %c %s))",
p[0], GetOper(oper[0]), p[1], GetOper(oper[1]), p[2], GetOper(oper[2]), p[3]);
break;
case 1:
sprintf(answer, "%s %c ((%s %c %s) %c %s)",
p[0], GetOper(oper[0]), p[1], GetOper(oper[1]), p[2], GetOper(oper[2]), p[3]);
break;
case 2:
sprintf(answer, "(%s %c %s) %c (%s %c %s)",
p[0], GetOper(oper[0]), p[1], GetOper(oper[1]), p[2], GetOper(oper[2]), p[3]);
break;
case 3:
sprintf(answer, "((%s %c %s) %c %s) %c %s",
p[0], GetOper(oper[0]), p[1], GetOper(oper[1]), p[2], GetOper(oper[2]), p[3]);
break;
case 4:
sprintf(answer, "(%s %c (%s %c %s)) %c %s",
p[0], GetOper(oper[0]), p[1], GetOper(oper[1]), p[2], GetOper(oper[2]), p[3]);
break;
}
}
bool TestResolve(char* question, int* oper, char* answer)
{
// 绛夊緟钥幂敓瀹屾垚
int type[5]={0,1,2,3,4};//璁$畻绫诲瀷
double p[4];
double sum=0;
//
for(int i=0; i<4; i++) //寰鐜鍙栧缑镣规暟
{
p[i]=GetCardValue(int(question[i]));
} for(i=0;i<5;i++)
{
MakeAnswer(answer,type[i],question,oper); //銮峰彇鍙鑳界殑绛旀
switch(type[i])
{
case 0:
sum=MyCalcu(p[0],MyCalcu( p[1],MyCalcu(p[2], p[3], oper[2]),oper[1]),oper[0]); //A*(B*(c*D))
break;
case 1:
sum=MyCalcu(p[0],MyCalcu(MyCalcu(p[1], p[2], oper[1]),p[3],oper[2]),oper[0]); //A*((B*C)*D)
break;
case 2:
sum=MyCalcu(MyCalcu(p[0], p[1], oper[0]),MyCalcu(p[2], p[3], oper[2]),oper[1]); // (A*B)*(C*D)
break;
case 3:
sum=MyCalcu(MyCalcu(MyCalcu(p[0], p[1], oper[0]),p[2],oper[1]),p[3],oper[2]); //((A*B)*C)*D
break;
case 4:
sum=MyCalcu(MyCalcu(p[0],MyCalcu(p[1], p[2], oper[1]),oper[0]),p[3],oper[2]); //(A*(B*C))*D
break;
}
if(sum==24) return true;
}
return false;
}
/*
閲囩敤闅忔満璇曟帰娉曪细灏辨槸阃氲繃闅忔満鏁板瓧浜х敓 锷犲噺涔橀櫎镄 缁勫悎锛岄氲繃澶ч噺镄勬祴璇曟潵锻戒腑镄勮В娉
鎻愮ず锛
1. 闇瑕佽冭槛鐢ㄦ嫭鍙锋带鍒惰$畻娆″簭镄勯梾棰 姣斿傦细( 10 - 4 ) * ( 3 + A ), 瀹为檯涓婅$畻娆″簭镄勬暟鐩鏄链夐檺镄勶细
A*(B*(c*D))
A*((B*C)*D)
(A*B)*(C*D)
((A*B)*C)*D
(A*(B*C))*D
2. 闇瑕佽冭槛璁$畻缁撴灉涓哄垎鏁扮殑𨱍呭喌锛( 3 + (3 / 7) ) * 7
3. 棰樼洰涓鐗岀殑浣岖疆鍙浠ヤ换镒忎氦鎹
*/
bool TryResolve(char* question, char* answer)
{
int oper[3]; // 瀛桦偍杩愮畻绗︼纴0:锷犳硶 1:鍑忔硶 2:涔樻硶 3:闄ゆ硶
for(int i=0; i<1000 * 1000; i++)
{
// 镓扑贡绾哥墝椤哄簭
shuffle(question);

// 闅忔満浜х敓杩愮畻绗
for(int j=0; j<3; j++)
oper[j] = rand() % 4; if( TestResolve(question, oper, answer) ) return true;
} return false;
}
int main(int argc, char* argv[])
{
// 鍒濆嫔寲闅忔満绉嶅瓙
srand( (unsigned)time( NULL ) ); char buf1[4]; // 棰樼洰
char buf2[30]; // 瑙g瓟
printf("***************************\n");
printf("璁$畻24\n");
printf("A J Q K 鍧囨寜1璁$畻锛屽叾瀹冩寜鐗岀偣璁$畻\n");
printf("鐩镙囨槸锛氶氲繃锲涘垯杩愮畻缁勫悎鍑虹粨鏋滐细24\n");
printf("***************************\n\n");
for(;;)
{
GivePuzzle(buf1); // 鍑洪
printf("棰樼洰锛");
for(int j=0; j<4; j++){
if( buf1[j] == 'T' )
printf("10 ");
else
printf("%c ", buf1[j]);
} printf("\n鎸変换镒忛敭鍙傝幂瓟妗...\n");
getch(); if( TryResolve(buf1, buf2) ) // 瑙i
printf("鍙傝冿细%s\n", buf2);
else
printf("鍙鑳芥槸镞犺В...\n"); printf("鎸変换镒忛敭鍑轰笅涓棰樼洰锛寈 阌阃鍑...\n");
if( getch() == 'x' ) break;
} return 0;
}

阅读全文

与一个简单游戏的编程相关的资料

热点内容
优先级队列java 浏览:154
轻量化腾讯云服务器有什么用 浏览:460
编译原理自编译语言 浏览:423
闲鱼app为什么这么多 浏览:690
安卓手机玩游戏不卡怎么设置 浏览:568
编译链接装载书 浏览:537
面试腾讯公司程序员 浏览:108
一个字母y是什么app 浏览:142
魔兽大脚解压安装教程 浏览:7
超时代共享文件夹破解版 浏览:441
命令与征服红色警戒3攻略 浏览:724
解压缩jar包 浏览:586
如何计算服务器的最大并发数 浏览:345
java数组类型定义 浏览:850
安卓卡一和卡二怎么切换 浏览:985
用价值观统领算法强化责任 浏览:783
外汇阿里云服务器买哪一种类型 浏览:448
绍兴程序员接私活攻略 浏览:644
java获取上传图片 浏览:50
主次梁交叉处箍筋加密长度 浏览:967