论坛交流
首页办公自动化| 网页制作| 平面设计| 动画制作| 数据库开发| 程序设计| 全部视频教程
应用视频: Windows | Word2007 | Excel2007 | PowerPoint2007 | Dreamweaver 8 | Fireworks 8 | Flash 8 | Photoshop cs | CorelDraw 12
编程视频: C语言视频教程 | HTML | Div+Css布局 | Javascript | Access数据库 | Asp | Sql Server数据库Asp.net  | Flash AS
当前位置 > 文字教程 > C语言程序设计教程
Tag:新手,函数,指针,数据类型,对象,Turbo,入门,运算符,数组,结构,二级,,tc,游戏,试题,问答,编译,视频教程

24点扑克牌游戏

文章类别:C语言程序设计 | 发表日期:2008-9-24 14:46:36

#include<stdio.h>
#include<graphics.h>
#include<ctype.h>
#include<time.h>
#include<stdlib.h>
#include<string.h>
#define COL 100
#define COM 40
#define max 20
char after[max];
typedef struct stack                                                                           /*定义栈1存放运算符*/
{
char stack[max];
int top;
}stack;
stack L;
typedef struct stack1                                                                       /*定义栈2计算表达式值*/
{
int stack1[max];
int top;
}stack1;
stack1 S;
void initstack(stack M)
{
M->top=0;
}
voidinitstack1(stack1 N)
{
N->top=0;
}
char  p[4][13]={
{'A','2,'3','4','5','6','7','8','9','0','J','Q','K'},
{'A','2,'3','4','5','6','7','8','9','0','J','Q','K'},
{'A','2,'3','4','5','6','7','8','9','0','J','Q','K'},
{'A','2,'3','4','5','6','7','8','9','0','J','Q','K'}
};
void play()                                                                                                           /*发牌函数*/
{
int j;
for(j=1;j<=4;j++)
{
bar(COL+100*j-35,COM+100-50,COL+100*j+35,COM+100+50);
setcolor(BLUE);
rectangle(COL+100*j-32,COM+100-48,COL+100*j+32,COM+100+48);
rand1(j);
delay(10000);
}
}
void rand1(int j)
{
int kind,number;
char str[3];
randomize();
while(1)
  {
   kind=random(4);
   num=random(13);
   if(p[kind][num]!=-1)
      {
        n=p[kind][num];
        p[kind][num]=-1;
        break;
      }
}
switch(kind)
{
case 0:
setcolor(RED);
sprintf(str,"%c",3);
break;
case 1:
setcolor(BLACK);
sprintf(str,"%c",3);
break;
case 2:
setcolor(RED);
sprintf(str,"%c",4);
break;
case 3:
setcolor(BLACK);
sprintf(str,"%c",5);
break;
}
settextstyle(0,0,2);
outtextxy(COL+j*100-30,ROW+100-46,str);
outtextxy(COL+j*100+16,ROW+100+32,str);
if(n!='0')
{
settextstyle(0,0,3);
sprintf(str,"%c",n);
outtextxy(COL+j*100-5,ROW+100-5,str);
}
else
{
sprintf("str,"%d",10);
outtextxy(COL+j*100-6,ROW+100-5,str);
}
}
int text1(char *s)                                                                                       /*显示文本*/
{
setbkcolor(BLUE);
cleardevice();
setcolor(12);
settextstyle(1,0,8);
outtextxy(120,120,s);
setusercharsize(2,1,4,1);
setcolor(15);
settextxy(220,220,s);
getch();
return;
}
void init()
{int gdriver,gmode;
gdriver=DETECT;
initgraph(&gdriver,&gmode,"d:\\turboc2");
cleardevice();
}
void close()
{
closegraph();
}
void change(char stm[])                                                                                                 /*将表达式的输出类型进行转换*/
{int i=0,j=0;
char ch;
initstack(L);
ch=stm[i];
while(ch!='\0')
{
      while(isdigit(ch)||ch='.')
              {
               after[j]=ch;
               j++;
              ch=stm[++i];
              }
     switch(ch)
              {
                case '+':
                case '-':
                            while(L->top!=0&&L->stack[L->top]!='(')
                                     {
                                      after[j]=L->stack[L->top];
                                      j++;
                                      L->top--;
                                     }
                                     L->top++;
                                     L->stack[L->top]=ch;
                                     break;
               case '*':
               case '/':
                            while(L->stack(L->top)=='*'||L->stack[L->top]='/')
                                    {
                                     after[j]=L->stack[L->top];
                                      j++;
                                     L->top--;
                                    }
                                     L->top++;
                                     L->stack[L->top]=ch;
                                     break;
                case '(':
                                     L->top++;
                                     L->stack[L->top]=ch;
                                     break;
               case ')':
                                     while(L->stack[L->top]!='('&&L->top!='\0')
                                              {
                                                after[j]=L->stack[L->top];
                                                j++;
                                                L->top--;
                                               }
                                      if(L->top==0)
                                             {
                                              printf("wrong input format!\n");
                                              exit(0);
                                             }
                                     L->top--;
                                     break;
                case ' ':
                                     break;
                default:
                                   printf("the express include illegal character!\n");
                                   exit(0);
                }
                i++;
                ch=stm[i];
}
while(L->top!=0)
{
   after[j]=L->stack[L->top];
   j++;
}
after[j]='\0';
printf("the changed expression is:");
puts(after);
printf("\n");
}
int compute()                                                                                                /*计算表达式的值*/
{
int m=0,n;
char ch;
initstack1(S);
ch=after[m];
while(ch!='\0')
  {
                 if(isdigit(ch))
                    {
                     n=0;
                     do
                      {
                     n=10*n+ch-'0';
                     ch=after[++m];
                     }while(ch!='.')
                    switch(ch)
                     {
                      case '+':
                                    S->stack1[S->top-1]=S->stack1[S->top-1]+S->stack1[S->top];
                                    S->top--;
                                    break;
                       case '-':
                                   S->stack1[S->top-1]=S->stack1[S->top-1]-S->stack1[S->top];
                                   S->top--;
                                   break;
                       case '*':
                                   S->stack1[S->top-1]=S->stack1[S->top]*S->stack1[S->top-1];
                                   S->top--;
                                   break;
                        case '/':
                                    S->stack1[S->top-1]=S->stack1[S->top-1]/S->stack1[S->top];
                                    S->top--;
                                    break;
                     }
                   ch=after[++m];
}
return S->stack1[S->top];
}

main()
{
int i,result;
char ch;
int gdriver,gmode;
clrscr();
init();                                                                                                                                          /*图形初始化*/
while(1)
{
setbkcolor(BLACK);
cleardevice();
play();
gotoxy(1,15);
printf("-----------------------------------note------------------------------------------------\n");                              /*表达式的输入*/
printf("Please enter express include only four numbers:\n");
printf("Format as follows:2.*(3.+5.)/2.\n");
printf("-----------------------------------------------------------------------------------------\n");
gets(str);
change(str);
result=compute();
if(result==24)
  text1("VERY GOOD!!!");
else
text1("WRONG!!!");
printf("continue?(Y or N)\n");
scanf("%c",&ch);
if(ch=='N'||ch=='n')
break;
}
close();                                                                                                                /*关闭图形*/
return;
}
视频教程列表
文章教程搜索
 
C语言程序设计推荐教程
C语言程序设计热门教程
看全部视频教程
购买方式/价格
购买视频教程: 咨询客服
tel:15972130058