一个24点的C程序

2006-9-23 寒川 计算机

#include "stdio.h"
#include "math.h"
#include "time.h"

void main()
{
  void first();
  void second();
  int third();
  time_t t;
  int close=0;
  char get;
  clrscr();
  srand((unsigned) time(&t));
  for(;;)
  {
    clrscr();
    printf("24 POINTS SYSTEM v2.2\n");
    printf("MADE BY DANTE WANG\n");
    printf("Jul.28th 2006\n\n");
    printf("Please choose mode!\n\n");
    printf("1. Game Mode\n");
    printf("2. Count Mode\n");
    printf("3. Quit\n\n");
    get=getch();
    switch(get)
    {
      case '1': first(); break;
      case '2': second();break;
      case '3': close=third(); break;
      default: printf("Please input 1, 2 or 3!\n"); getch();
    }
    if(close)
      break;
  }
}

void first()
{
  int jdgsgn(int a,int b,int c,int d);
  int n[4],i;
  char ch[100],ch1[100];
  int check(char *p);
  int exam2(char *p,int a,int b,int c,int d);
  void sign(int a,int b,int c,int d);
  double figure(char *p);
  void draw(int *p);
  for(;;)
  {
    for(i=0;i<4;i++)
    {
      n[i]=rand()%13+1;
    }
    draw(n);
    if(!jdgsgn(n[0],n[1],n[2],n[3]))
    {
      printf("No answer!");
      getch();
      continue;
    }
    gets(ch);
    if(!strcmp(strlwr(ch),"quit"))
    break;
    else
    {
      strcpy(ch1,ch);
      if(!check(ch)&&!exam2(ch,n[0],n[1],n[2],n[3])&&fabs(figure(ch1)-24)<=0.000001)
      {
printf("\nGood job!\n");
getch();
      }
      else
      {
printf("\nWrong!\n\nAnswer: ");
sign(n[0],n[1],n[2],n[3]);
getch();
      }
    }
  }
}

void second()
{
  int n[4],i;
  char c[4][10];
  int exam(char *p);
  void sign(int a,int b,int c,int d);
  double recog(char *p);
  clrscr();
  printf("Input 0 to leave.\n\n");
  for(;;)
  {
    for(i=0;i<4;i++)
    {
      scanf("%s",&c[i]);
      if(exam(c[i]))
      {
printf("GRAMMER ERROR!\n");
i--;
continue;
      }
      n[i]=(int)recog(c[i]);
      if(n[i]==0)
break;
    }
    if(n[0]&&n[1]&&n[2]&&n[3])
      sign(n[0],n[1],n[2],n[3]);
    else
      break;
  }
}

int third()
{
  printf("Thanks for using this software!\n\n");
  printf("If you have any advices or suggestions,\n\n");
  printf("please call my QQ:331349451\n\n");
  getch();
  return(1);
}

void sign(int a,int b,int c,int d)
{
  char *change(int x);
  double figure(char *p);
  int i[4],n,n1,n2,n3,n4,s1,s2,s3,t,flag=0;
  char s[4][2]={"+","-","*","/"},p[64]={0},p1[64]={0};
  i[0]=a;
  i[1]=b;
  i[2]=c;
  i[3]=d;
  for(n1=0;n1<4;n1++)
  {
    for(n2=0;n2<4;n2++)
    {
      if(n2==n1)
continue;
      for(n3=0;n3<4;n3++)
      {
if(n3==n2||n3==n1)
  continue;
for(n4=0;n4<4;n4++)
{
  if(n4==n3||n4==n2||n4==n1)
    continue;
  for(s1=0;s1<4;s1++)
  {
    for(s2=0;s2<4;s2++)
    {
      for(s3=0;s3<4;s3++)
      {
strcat(p,change(i[n1]));
strcat(p,s[s1]);
strcat(p,change(i[n2]));
strcat(p,s[s2]);
strcat(p,change(i[n3]));
strcat(p,s[s3]);
strcat(p,change(i[n4]));
strcpy(p1,p);
if(fabs(figure(p1)-24)<=0.000001)
{
  printf("%s\n",p);
  flag++;
  break;
}
*p='\0';
if(s1/2==1&&(s2/2==0||s3/2==0))
{
  strcat(p,change(i[n1]));
  strcat(p,s[s1]);
  strcat(p,"(");
  strcat(p,change(i[n2]));
  strcat(p,s[s2]);
  strcat(p,change(i[n3]));
  strcat(p,s[s3]);
  strcat(p,change(i[n4]));
  strcat(p,")");
  strcpy(p1,p);
  if(fabs(figure(p1)-24)<=0.000001)
  {
    printf("%s\n",p);
    flag++;
    break;
  }
  *p='\0';
}
if(s1/2==0&&s2/2==1)
{
  strcat(p,"(");
  strcat(p,change(i[n1]));
  strcat(p,s[s1]);
  strcat(p,change(i[n2]));
  strcat(p,")");
  strcat(p,s[s2]);
  strcat(p,change(i[n3]));
  strcat(p,s[s3]);
  strcat(p,change(i[n4]));
  strcpy(p1,p);
  if(fabs(figure(p1)-24)<=0.000001)
  {
    printf("%s\n",p);
    flag++;
    break;
  }
  *p='\0';
}
if(s2/2==0&&s1/2==1)
{
  strcat(p,change(i[n1]));
  strcat(p,s[s1]);
  strcat(p,"(");
  strcat(p,change(i[n2]));
  strcat(p,s[s2]);
  strcat(p,change(i[n3]));
  strcat(p,")");
  strcat(p,s[s3]);
  strcat(p,change(i[n4]));
  strcpy(p1,p);
  if(fabs(figure(p1)-24)<=0.000001)
  {
    printf("%s\n",p);
    flag++;
    break;
  }
  *p='\0';
}
if((s1/2==0||s2/2==0)&&s3/2==1)
{
  strcat(p,"(");
  strcat(p,change(i[n1]));
  strcat(p,s[s1]);
  strcat(p,change(i[n2]));
  strcat(p,s[s2]);
  strcat(p,change(i[n3]));
  strcat(p,")");
  strcat(p,s[s3]);
  strcat(p,change(i[n4]));
  strcpy(p1,p);
  if(fabs(figure(p1)-24)<=0.000001)
  {
    printf("%s\n",p);
    flag++;
    break;
  }
  *p='\0';
}
if(s1/2==0&&s2/2==1&&s3/2==0)
{
  strcat(p,"(");
  strcat(p,change(i[n1]));
  strcat(p,s[s1]);
  strcat(p,change(i[n2]));
  strcat(p,")");
  strcat(p,s[s2]);
  strcat(p,"(");
  strcat(p,change(i[n3]));
  strcat(p,s[s3]);
  strcat(p,change(i[n4]));
  strcat(p,")");
  strcpy(p1,p);
  if(fabs(figure(p1)-24)<=0.000001)
  {
    printf("%s\n",p);
    flag++;
    break;
  }
  *p='\0';
}
      }
      if(flag)
break;
    }
    if(flag)
      break;
  }
  if(flag)
    break;
}
if(flag)
  break;
      }
      if(flag)
break;
    }
    if(flag)
      break;
  }
  if(flag==0)
  printf("No answer!\n");
}

char *change(int x)
{
  static char a[64];
  char *c;
  c=a+63;
  *c='\0';
  c--;
  for(;;c--)
  {
    if(x>=10)
    {
      *c=x%10+'1'-1;
      x=x/10;
    }
    else
    {
      *c=x+'1'-1;
      break;
    }
  }
  return(c);
}

double figure(char *p)
{
  int judge(char *p);
  int judge2(char *p);
  void add(char *p);
  void pick(char *p);
  double recog(char *p);
  char *c=p,*c1,c2[64];
  int sign,kuoh=0,flag2=0;
  double result,chu;
  add(p);
  for(sign=0;*c!='\0';c++)
  {
    if(*c=='+'||*c=='-'||*c=='*'||*c=='/'||*c=='('||*c==')')
    {
      sign++;
      break;
    }
}
  if(sign==0)
    return(recog(p));
  else
  {
    c=p;
    for(;*c!='\0';c++)
    {
      if(*c=='(')
kuoh++;
      if(*c==')')
kuoh--;
      if(!judge2(c))
      {
if(*c=='+'&&kuoh==0)
{
  *c='\0';
  result=figure(p)+figure(c+1);
  flag2++;
  break;
}
if(*c=='-'&&kuoh==0)
{
  *c='\0';
  result=figure(p)-figure(c+1);
  flag2++;
  break;
}
      }
      if(!judge(c))
      {
if(*c=='*'&&kuoh==0)
{
  *c='\0';
  result=figure(p)*figure(c+1);
  flag2++;
  break;
}
if(*c=='/'&&kuoh==0)
{
  *c='\0';
  chu=figure(c+1);
  if(chu==0)
  {
    result=99999;
  }
  else
  {
    result=figure(p)/chu;
  }
  flag2++;
  break;
}
      }
    }
    if(flag2)
      return(result+0);
    else
    {
      pick(p);
      result=figure(p);
      return(result+0);
    }
  }
}

int judge(char *p)
{
  char *c=p;
  int kuoh=0,flag=0;
  for(c++;*c!='\0';c++)
  {
    if(*c=='(')
    kuoh++;
    if(*c==')')
    kuoh--;
    if(kuoh==0&&(*c=='+'||*c=='-'||*c=='*'||*c=='/'))
    {
      flag++;
      break;
    }
  }
  return(flag);
}

int judge2(char *p)
{
  char *c=p;
  int kuoh=0,flag=0;
  for(c++;*c!='\0';c++)
  {
    if(*c=='(')
    kuoh++;
    if(*c==')')
    kuoh--;
    if(kuoh==0&&(*c=='+'||*c=='-'))
    {
      flag++;
      break;
    }
  }
  return(flag);
}

void add(char *p)
{
  char *c=p,b[64];
  int flag=0;
  for(;*c!='\0';c++)
  {
    if((*c=='-'||*c=='+')&&(*(c+1)>='0'&&*(c+1)<='9'))
      flag++;
    if((*c>='0'&&*c<='9'||*c=='.')&&(*(c+1)=='*'||*(c+1)=='/'||*(c+1)=='+'||*(c+1)=='-'))
    {
      flag++;
      break;
    }
    if((*c>='0'&&*c<='9'||*c=='.')&&*(c+1)==')')
    {
      break;
    }
  }
  if(flag==2)
    flag=1;
  else
    flag=0;
  if(flag)
  {
    c=p;
    for(;*c!='\0';c++)
    {
      if(*(c+1)>='0'&&*(c+1)<='9')
      {
if(*c=='+'||*c=='-')
{
  strcpy(b,c);
  *c='(';
  strcpy(c+1,b);
}
break;
      }
    }
    c+=2;
    for(;*c!='\0';c++)
    {
      if((*c<'0'||*c>'9')&&*c!='.')
      {
strcpy(b,c);
*c=')';
strcpy(c+1,b);
break;
      }
    }
  }
}

void pick(char *p)
{
  char *c=p;
  if(*c=='('&&*(c+strlen(c)-1)==')')
  {
    strcpy(c,c+1);
    *(c+strlen(c)-1)='\0';
  }
}


double recog(char *p)
{
  char *c=p;
  int flag=0,number;
  double quan,ans=0;
  for(;;c++)
  {
    if(*c=='.')
    {
      flag++;
      number=c-p;
    }
    if(*c!='.'&&(*c<'0'||*c>'9'))
      break;
  }
  if(flag==0)
  {
    for(quan=1,c--;c>=p;c--,quan*=10)
    ans+=(*c-'1'+1)*quan;
  }
  else
  {
    for(c--,quan=pow(10,number-(c-p));c>=p;c--)
    {
      if(*c=='.')
continue;
      else
      {
ans+=(*c-'1'+1)*quan;
quan*=10;
      }
    }
  }
  return(ans);
}

int exam(char *p)
{
  double recog(char *p);
  char *c=p;
  int number=0;
  for(;*c!='\0';c++)
  {
    if(*c>'9'||*c<'0')
      number++;
    if(number)
      break;
  }
  if(!number)
  {
    if(recog(p)>13||recog(p)<0)
number++;
  }
  return(number);
}

void draw(int *p)
{
  time_t t;
  int n;
  clrscr();
  printf("Press \"quit\" to leave.");
  srand((unsigned) time(&t));
  for(n=0;n<4;n++)
  {
    gotoxy(1+7*n,3);
    printf("\xda\xc4\xc4\xc4\xc4\xbf");
    gotoxy(1+7*n,4);
    printf("\xb3%c   \xb3",rand()%4+3);
    gotoxy(1+7*n,5);
    printf("\xb3    \xb3");
    gotoxy(1+7*n,6);
    switch(*(p+n))
    {
      case 1:
printf("\xb3   A\xb3");
break;
      case 2:case 3:case 4:case 5:case 6:case 7:case 8:case 9:case 10:
printf("\xb3%4d\xb3",*(p+n));
break;
      case 11:
printf("\xb3   J\xb3");
break;
      case 12:
printf("\xb3   Q\xb3");
break;
      case 13:
printf("\xb3   K\xb3");
    }
    gotoxy(1+7*n,7);
    printf("\xc0\xc4\xc4\xc4\xc4\xd9");
    gotoxy(1,9);
  }
}

int jdgsgn(int a,int b,int c,int d)
{
  char *change(int x);
  double figure(char *p);
  int i[4],n,n1,n2,n3,n4,s1,s2,s3,t,flag=0;
  char s[4][2]={"+","-","*","/"},p[64]={0},p1[64]={0};
  i[0]=a;
  i[1]=b;
  i[2]=c;
  i[3]=d;
  for(n1=0;n1<4;n1++)
  {
    for(n2=0;n2<4;n2++)
    {
      if(n2==n1)
continue;
      for(n3=0;n3<4;n3++)
      {
if(n3==n2||n3==n1)
  continue;
for(n4=0;n4<4;n4++)
{
  if(n4==n3||n4==n2||n4==n1)
    continue;
  for(s1=0;s1<4;s1++)
  {
    for(s2=0;s2<4;s2++)
    {
      for(s3=0;s3<4;s3++)
      {
strcat(p,change(i[n1]));
strcat(p,s[s1]);
strcat(p,change(i[n2]));
strcat(p,s[s2]);
strcat(p,change(i[n3]));
strcat(p,s[s3]);
strcat(p,change(i[n4]));
strcpy(p1,p);
if(fabs(figure(p1)-24)<=0.000001)
{
  flag++;
  break;
}
*p='\0';
if(s1/2==1&&(s2/2==0||s3/2==0))
{
  strcat(p,change(i[n1]));
  strcat(p,s[s1]);
  strcat(p,"(");
  strcat(p,change(i[n2]));
  strcat(p,s[s2]);
  strcat(p,change(i[n3]));
  strcat(p,s[s3]);
  strcat(p,change(i[n4]));
  strcat(p,")");
  strcpy(p1,p);
  if(fabs(figure(p1)-24)<=0.000001)
  {
    flag++;
    break;
  }
  *p='\0';
}
if(s1/2==0&&s2/2==1)
{
  strcat(p,"(");
  strcat(p,change(i[n1]));
  strcat(p,s[s1]);
  strcat(p,change(i[n2]));
  strcat(p,")");
  strcat(p,s[s2]);
  strcat(p,change(i[n3]));
  strcat(p,s[s3]);
  strcat(p,change(i[n4]));
  strcpy(p1,p);
  if(fabs(figure(p1)-24)<=0.000001)
  {
    flag++;
    break;
  }
  *p='\0';
}
if(s2/2==0&&s1/2==1)
{
  strcat(p,change(i[n1]));
  strcat(p,s[s1]);
  strcat(p,"(");
  strcat(p,change(i[n2]));
  strcat(p,s[s2]);
  strcat(p,change(i[n3]));
  strcat(p,")");
  strcat(p,s[s3]);
  strcat(p,change(i[n4]));
  strcpy(p1,p);
  if(fabs(figure(p1)-24)<=0.000001)
  {
    flag++;
    break;
  }
  *p='\0';
}
if((s1/2==0||s2/2==0)&&s3/2==1)
{
  strcat(p,"(");
  strcat(p,change(i[n1]));
  strcat(p,s[s1]);
  strcat(p,change(i[n2]));
  strcat(p,s[s2]);
  strcat(p,change(i[n3]));
  strcat(p,")");
  strcat(p,s[s3]);
  strcat(p,change(i[n4]));
strcpy(p1,p);
  if(fabs(figure(p1)-24)<=0.000001)
  {
    flag++;
    break;
  }
  *p='\0';
}
if(s1/2==0&&s2/2==1&&s3/2==0)
{
  strcat(p,"(");
  strcat(p,change(i[n1]));
  strcat(p,s[s1]);
  strcat(p,change(i[n2]));
  strcat(p,")");
  strcat(p,s[s2]);
  strcat(p,"(");
  strcat(p,change(i[n3]));
  strcat(p,s[s3]);
  strcat(p,change(i[n4]));
  strcat(p,")");
  strcpy(p1,p);
  if(fabs(figure(p1)-24)<=0.000001)
  {
    flag++;
    break;
  }
  *p='\0';
}
      }
      if(flag)
break;
    }
    if(flag)
      break;
  }
  if(flag)
    break;
}
if(flag)
  break;
      }
      if(flag)
break;
    }
    if(flag)
      break;
  }
  return(flag);
}

int exam2(char *p,int a,int b,int c,int d)
{
  double recog(char *p);
  int number=0,num[4],flag=0,n,m;
  num[0]=a;
  num[1]=b;
  num[2]=c;
  num[3]=d;
  for(m=0;*p!='\0';p++,m++)
  {
    if(*p>='0'&&*p<='9'&&(*(p+1)>'9'||*(p+1)<'0'))
      number++;
    if(m>0&&*p>='0'&&*p<='9'&&*(p-1)>='0'&&*(p-1)<='9')
      continue;
    if(*p<='9'&&*p>='0')
    {
      if(recog(p)>13||recog(p)<1)
      {
flag++;
break;
      }
      else
      {
for(n=0;n<4;n++)
{
  if(recog(p)==num[n])
  {
    num[n]=0;
    break;
  }
}
      }
    }
  }
  if(!flag)
  {
    if(number!=4)
      flag++;
    else
      if(num[1]||num[2]||num[3]||num[0])
flag++;
  }
  return(flag);
}

int check(char *p)
{
  int kuoh=0,flag=0;
  for(;*p!='\0';p++)
  {
    if(*p==' ')
    {
      flag++;
      break;
    }
    if(kuoh<0)
    {
      flag++;
      break;
    }
    if(*p=='(')
      kuoh++;
    if(*p==')')
      kuoh--;
    if((*p=='+'||*p=='-'||*p=='*'||*p=='/')&&(*(p+1)=='*'||*(p+1)=='/'||*(p+1)=='+'||*(p+1)=='-'))
    {
      flag++;
      break;
    }
    if(*p=='('&&(*(p+1)>'9'||*(p+1)<'0'&&*(p+1)!='-'))
    {
      flag++;
      break;
    }
    if(*p==')'&&*(p+1)!='+'&&*(p+1)!='-'&&*(p+1)!='*'&&*(p+1)!='/'&&*(p+1)!='\0')
    {
      flag++;
      break;
    }
  }
  if(!flag)
  {
    if(kuoh!=0)
      flag++;
  }
  return(flag);
}

标签: 心情 编程

评论(0) 浏览(6420)

C语言写的一个万年历

2006-9-23 寒川 计算机

#include<string.h>
#include<bios.h>
#include<stdlib.h>
#include<conio.h>
#define LEFT 0x4b00
#define RIGHT 0x4d00
#define ESC 0x011b
#define ENTER 0x1c0d
char *a[4]={"left","right","up","down"};
int num=3000,key,year=2006;
int i,j,first=3,w=30;
char *month[12]={"Junuary","February","March","April","May","June","July","August","September","October","November","December"};
int mon[12]={31,28,31,30,31,30,31,31,30,31,30,31};
int fd[12]={0};

int getkey()
{char lowbyte;
 int press;
 while(bioskey(1)==0)
    press=bioskey(0);
 lowbyte=press&0xff;
 press=press&0xff00+toupper(lowbyte);
 return(press);
}

void sch()
{window(22,24,30,24);
 textbackground(GREEN);
 clrscr();
 textcolor(15);
 cprintf("\n Search");}


void sch_0()
{window(22,24,30,24);
 textbackground(GREEN);
 clrscr();
 textcolor(128);
 cprintf("\n Search ");}


 void backk()

 {window(33,24,42,24);
 textbackground(GREEN);
 clrscr();
 textcolor(15);
 cprintf("\n Month1-4");}


 void backk_0()
 {window(33,24,42,24);
 textbackground(GREEN);
 clrscr();
 textcolor(128);
 cprintf("\n Month1-4");}


void left()
{
 window(45,24,54,24);
 textbackground(GREEN);
 clrscr();
 textcolor(15);
 cprintf("\n Month5-8");}


 void left_0()
{
 window(45,24,54,24);
 textbackground(GREEN);
 clrscr();
 textcolor(128);
 cprintf("\n Month5-8");}


void right()
{window(57,24,67,24);
 textbackground(GREEN);
 clrscr();
 textcolor(15);
 cprintf("\n Month9-12");}


void right_0()
{window(57,24,67,24);
 textbackground(GREEN);
 clrscr();
 textcolor(128);
 cprintf("\n Month9-12");}

 

 

 

void iexit()
{window(70,24,77,24);
 textbackground(GREEN);
 clrscr();
 textcolor(15);
 cprintf("\n  Exit");}


void iexit_0()
{window(70,24,77,24);
 textbackground(GREEN);
 clrscr();
 textcolor(128);
 cprintf("\n  Exit");}

 

 


void jiance(int n)
{switch(n)
   {case 0:sch_0();left();right();iexit();backk();break;
    case 1:backk_0();left();right();iexit();sch();break;
    case 2:left_0();right();iexit();sch();backk();break;
    case 3:right_0();left();iexit();sch();backk();break;
    case 4:iexit_0();left();right();sch();backk();break;
    default:exit(0);
    }

}


void quzhi()
{window(8,24,20,24);
 textbackground(15);
 clrscr();
 textcolor(RED);
 cscanf("%d",&year);
}

 

 

 void month1_4()
 {
for(i=0;i<2;i++)
    {window(2+i*w,3,29+w*i,11);
     textbackground(5);
     clrscr();
     textcolor(GREEN);
     cprintf("            %s\n",month[i]);
     gotoxy(1,2);cprintf(" Mon Tue Wed Thu Fri Sat Sun");
     gotoxy(4*(fd[i]-1)+1,3);
     for(j=1;j<=mon[i];j++)
    {cprintf("%3d ",j);
     /*if((first+j-1)%7==0)putchar('\n');*/
     }
     /*first=(first+mon[i])%7;
     if(first==0)first=7;*/
     }
 for(i=2;i<4;i++)
    {window(2+(i-2)*w,13,29+w*(i-2),21);
     textbackground(5);
     clrscr();
     textcolor(GREEN);
     cprintf("            %s\n",month[i]);
     gotoxy(1,2);cprintf(" Mon Tue Wed Thu Fri Sat Sun");
     gotoxy(4*(fd[i]-1)+1,3);
for(j=1;j<=mon[i];j++)
    {cprintf("%3d ",j);
     /*if((first+j-1)%7==0)putchar('\n');*/
     }
     /*first=(first+mon[i])%7;
     if(first==0)first=7;*/
}
}

 


   void month5_8()
 {for(i=0;i<2;i++)
    {window(2+i*w,3,29+w*i,11);
     textbackground(5);
     clrscr();
     textcolor(GREEN);
     cprintf("            %s\n",month[i+4]);
     gotoxy(1,2);cprintf(" Mon Tue Wed Thu Fri Sat Sun");
     gotoxy(4*(fd[i+4]-1)+1,3);
     for(j=1;j<=mon[i+4];j++)
    {cprintf("%3d ",j);
     /*if((first+j-1)%7==0)putchar('\n');*/
     }
     /*first=(first+mon[i+4])%7;
     if(first==0)first=7;*/
}
 for(i=2;i<4;i++)
    {window(2+(i-2)*w,13,29+w*(i-2),21);
     textbackground(5);
     clrscr();
     textcolor(GREEN);
     cprintf("           %s",month[i+4]);
     gotoxy(1,2);cprintf(" Mon Tue Wed Thu Fri Sat Sun");
     gotoxy(4*(fd[i+4]-1)+1,3);
     for(j=1;j<=mon[i+4];j++)
    {cprintf("%3d ",j);
     /*if((first+j-1)%7==0)putchar('\n');*/
     }
     /*first=(first+mon[i+4])%7;
     if(first==0)first=7;*/
}
}


void month9_12()
{for(i=0;i<2;i++)
    {window(2+i*w,3,29+w*i,11);
     textbackground(5);
     clrscr();
     textcolor(GREEN);
     cprintf("            %s\n",month[i+8]);
     gotoxy(1,2);cprintf(" Mon Tue Wed Thu Fri Sat Sun");
     gotoxy(4*(fd[i+8]-1)+1,3);
     for(j=1;j<=mon[i+8];j++)
    {cprintf("%3d ",j);
     /*if((first+j-1)%7==0)putchar('\n');*/
     }
     /*first=(first+mon[i+8])%7;
     if(first==0)first=7;*/
}
 for(i=2;i<4;i++)
    {window(2+(i-2)*w,13,29+w*(i-2),21);
     textbackground(5);
     clrscr();
     textcolor(GREEN);
     cprintf("            %s",month[i+8]);
     gotoxy(1,2);cprintf(" Mon Tue Wed Thu Fri Sat Sun");
     gotoxy(4*(fd[i+8]-1)+1,3);
     for(j=1;j<=mon[i+8];j++)
    {cprintf("%3d ",j);
     /*if((first+j-1)%7==0)putchar('\n');*/
     }
     /*first=(first+mon[i+8])%7;
     if(first==0)first=7;*/
}
}

 


void calendar(int year)
{int x,cha;
 long day=0;
 window(1,2,80,22);
 textbackground(YELLOW);
 clrscr();
 if(year<2007)
     {for(x=year;x<2007;x++)
   {if((x%4==0&&x%100!=0)||x%400==0)
    day+=366;
    else day+=365;}
       cha=day%7;
       first=(7+1-cha)%7;
       if(first==0)first=7;
       }
 if(year==2007)first=1;
 if(year>2007)
     {for(x=2007;x<year;x++)
  {if((x%4==0&&x%100!=0)||x%400==0)
    day+=366;
    else day+=365;}
       cha=day%7;
       first=(1+cha)%7;
       if(first==0)first=7;
     }
 if((year%4==0&&year%100!=0)||year%400==0)
   mon[1]=29;
 else mon[1]=28;
 fd[0]=first;
 for(j=1;j<12;j++)
    {fd[j]=(fd[j-1]+mon[j-1])%7;
     if(fd[j]==0)fd[j]=7;}
 month1_4();}

 


void jiance2(int n)
{void nian(int year);
 switch(n)
    {case 0:getch( );quzhi();calendar(year);nian(year);break;
     case 1:month1_4();break;
     case 2:month5_8();break;
     case 3:month9_12();break;
     case 4:exit(0);break;
     default:exit(0);}
}

 

void ping()
{clrscr();
 window(1,1,80,1);
 textbackground(RED);
clrscr();
 gotoxy(6,1);
 textcolor(GREEN);
 cprintf("FILE   Record   Link    Help");
 window(2,1,4,1);
 textbackground(0);
 clrscr();
 window(1,2,80,22);
 textbackground(YELLOW);
 clrscr();
 window(1,23,80,25);
 textbackground(BLUE);
 clrscr();
 window(8,24,20,24);
 textbackground(15);
 clrscr();
 sch_0();
 left();
 right();
 iexit();
 backk();
 calendar(2006);
}

 

void copyright()
{clrscr();
 window(15,5,65,15);
 textbackground(RED);
 clrscr();
 textcolor(GREEN);
 cprintf("\n                  Calendar\n");
 gotoxy(1,4);
 cprintf("         My QQ: 331349451 Tel:08135507131\n");
 gotoxy(1,6);
 cprintf("               >September 19th,2006");
 gotoxy(1,8);
 cprintf("      Sichuan University of Scienc and Engineering  ");
 gotoxy(1,10);
 cprintf("             Jingxi Class 2,Grade 2004");
}


void nian(int year)
{window(62,5,78,5);
 textbackground(RED);
 clrscr();
 textcolor(GREEN);
 cprintf("\n    Calendar");
 window(64,7,75,11);
 textbackground(15);
 clrscr();
 textcolor(1);
 cprintf("\n    Year");
 gotoxy(3,4);
 cprintf("%6d",year);
 window(62,13,78,20);
 textbackground(8);
 clrscr();
 textcolor(9);
 cprintf("\n  Copyright(c)");
 gotoxy(1,4);
 cprintf(" Xieyan Wei");
 gotoxy(1,6);
 cprintf(" xieyanwei1985@163.com");
 return;
 }

 


main()
{clrscr();
 window(1,1,80,1);
 textbackground(RED);
 clrscr();
 gotoxy(6,1);
 textcolor(GREEN);
 cprintf("FILE   Record   Link    Help");
 window(2,1,4,1);
 textbackground(0);
 clrscr();
 window(1,2,80,22);
 textbackground(YELLOW);
 clrscr();
 window(1,23,80,25);
 textbackground(BLUE);
 clrscr();
 window(8,24,20,24);
 textbackground(15);
 clrscr();
 copyright();
 sch_0();
 backk();
 left();
 right();
 iexit();
 getch();
 ping();
 calendar(2006);
 nian(2006);
 while(key!=28)
    {if(bioskey(1))key=bioskey(0);
     switch(key)
{case LEFT:num--;jiance(num%5);key=0;break;
 case RIGHT:num++;jiance(num%5);key=0;break;
 case ENTER:jiance2(num%5);key=0;break;
 case ESC:exit(0);
 default:key=0;break;}
     }

}
 

标签: 编程 C

评论(0) 浏览(7032)

二级是狗屎

2006-9-23 寒川 点滴心情

我不是因为没考过2级才这么说。虽然我很想过2级,但是说实在的,就我们这些非计算机专业的学生,过了二级也还是计算机白痴,这可不是吹牛的!什么C语言,什么VB,什么Access,学得要懂不懂的。一点适用价值都没有。但是出去工作企业要看你的计算机等级证书。真不知道那些老板们是怎么想的。其实他们一点都不知道,即使是过了计算机2级的,也没几个能搞出一个多么好的程序来。
  我报了两次计算机了,即使这次能过,我照样说2级是狗屎。这不是吹的!……
  还不如学点有用的计算机基础。比如:Powerpint、 Word、Fontpage、Excel、Auto CAD、Photoshop CS。呵呵~~我觉得这些比起无聊的程序来安逸得多了。

标签: 计算机 学习

评论(0) 浏览(6472)

上网中

2006-9-21 寒川 点滴心情

    又快要2级考试了,不知道这次是否能过?真他妈的难. 好不安逸哦。想认真学习C现在是不可能的了。最近特别喜欢C,但是以前学了都忘了好多。怎么考试?!

 

标签: 心情 学习

评论(0) 浏览(6950)

搬校区了

2006-7-14 寒川 点滴心情

搬校区了。真是不安逸!

标签: 心情

评论(2) 浏览(7348)

Powered by emlog 蜀ICP备12030225号

川公网安备 51042102000001号

sitemap