实现语言C语言简单实现五子棋

在改章节中,我们主要介绍实现语言的内容,自我感觉有个不错的建议和大家分享下

    五子棋实现代码

#include<stdio.h>
#define M 9
#define N 9
void print(int a[M][N])
{
	int i,j;
	for(i=0;i<M;i++)
	{
		for(j=0;j<N;j++)
			printf(" %d",a[i][j]);
		printf("\n");
	}
}
int check(int a[M][N])
{
	int i,j;
	for(i=0;i<M-5;i++)
	{
		for(j=0;j<N-5;j++)
		{
			if((a[i][j]==1)&&(a[i+1][j]==1)&&(a[i+2][j]==1)&&(a[i+3][j]==1)&&(a[i+4][j]==1))
			{
				printf("player1 win\n");
				return 0;
				break;
			}
			else if((a[i][j]==1)&&(a[i][j+1]==1)&&(a[i][j+2]==1)&&(a[i][j+3]==1)&&(a[i][j+4]==1))
			{
				printf("player1 win\n");
				return 0;
				break;
			}
			else if((a[i][j]==1)&&(a[i+1][j+1]==1)&&(a[i+2][j+2]==1)&&(a[i+3][j+3]==1)&&(a[i+4][j+4]==1))
			{
				printf("player1 win\n");
				return 0;
				break;
			}
			else if((a[M-i][j]==1)&&(a[M-i-1][j+1]==1)&&(a[M-i-2][j+2]==1)&&(a[M-i-3][j+3]==1)&&(a[M-i-4][j+4]==1))
			{
				printf("player1 win\n");
				return 0;
				break;
			}

			if((a[i][j]==2)&&(a[i+1][j]==2)&&(a[i+2][j]==2)&&(a[i+3][j]==2)&&(a[i+4][j]==2))
			{
				printf("player2 win\n");
				return 0;
				break;
			}
			else if((a[i][j]==2)&&(a[i][j+1]==2)&&(a[i][j+2]==2)&&(a[i][j+3]==2)&&(a[i][j+4]==2))
			{
				printf("player2 win\n");
				return 0;
				break;
			}
			else if((a[i][j]==2)&&(a[i+1][j+1]==2)&&(a[i+2][j+2]==2)&&(a[i+3][j+3]==2)&&(a[i+4][j+4]==2))
			{
				printf("player2 win\n");
				return 0;
				break;
			}
			else if((a[M-i][j]==2)&&(a[M-i-1][j+1]==2)&&(a[M-i-2][j+2]==2)&&(a[M-i-3][j+3]==2)&&(a[M-i-4][j+4]==2))
			{
				printf("player2 win\n");
				return 0;
				break;
			}
		}
	}
	return 1;
}

int main()
{
	int a[M][N]={0},b[M][N]={0};
	print(a);
	int i,j;
	int count=1,num=0;
	while(count)
	{
		num++;
		if(num%2==1)
		{
			printf("player1 input:");
			scanf("%d",&i);
			scanf("%d",&j);
			a[i-1][j-1]=1;
			print(a);
			count=check(a);
			for(i=0;i<M;i++)
				for(j=0;j<N;j++)
					b[i][j]=a[i][j];
		}
		else if(num%2==0)
		{
			printf("player2 input:");
			scanf("%d",&i);
			scanf("%d",&j);
			b[i-1][j-1]=2;
			print(b);
			count=check(b);
			for(i=0;i<M;i++)
				for(j=0;j<N;j++)
					a[i][j]=b[i][j];
		}
	}
	return 0;
}
    每日一道理
试试看——不是像企鹅那样静静的站在海边,翘首企盼机会的来临,而是如苍鹰一般不停的翻飞盘旋,执著的寻求。 试试看——不是面对峰回路转、杂草丛生的前途枉自嗟叹,而是披荆斩棘,举步探索。 试试看——不是拘泥于命运的禁锢,听凭命运的摆布,而是奋力敲击其神秘的门扉,使之洞开一个新的天地。微笑着,去唱生活的歌谣。

    在redhat上运行

    实现和语言

文章结束给大家分享下程序员的一些笑话语录: 话剧:程序员过沟
  本剧内容纯属虚构,如有雷同……HEHE……俺也没办法了。
  话说某市街道改建,某某软件公司门口横七竖八挖了几条大沟。一群程序员(SDK程序员赵某,VB程序员钱某,VC程序员孙某,DELPHI程序员李某)下班从公司里出来,看到门前的几条沟,于是各显神通……门前第一条沟也就半米来宽,SDK程序员赵某二话没说,轻轻一跃跳了过去,看到其它人纷纷把随身携带的公文包(类库)横在沟上踩着过沟,不屑地说,这么小一条沟,犯得着小题大做用那个吗?看我多么轻松多么洒脱多么……多么……(众人皆怒目横视之……)
  接着第二条沟有点宽度。SDK程序员赵某还是还是一马当先,飞跃而起……不好,还差一点才到……幸好凭着多年的(跳远?编程?)经验,单手抓住沟沿,颤巍巍地爬了上来,嘴里还念念有词“高手就是高手啊,虽然差一点就……不过毕竟……HEHE……跳远是过沟的基础嘛,有基础(SDK)就有一切的说……”(众人作瞠目结舌状……)看到别人跳过去了,可自己又跳不了那么远,只好再想办法了……VB程序员钱某,DELPHI程序员李某打开手提,连上手机,开始上网找可供过沟的控件……VC程序员孙某却不慌不忙,打开公文包,把几块衬板拆了下来,然后三下五除二拼成一个简易木桥……“虽然这几个板子(类)做得不怎么样,不过先把这个项目应付过去,有时间我自己做一个好了……”于是踩着板子过了沟。
  这时钱某和李某也分别找到了合适的东东。钱某找到的是“钢丝绳.ocx”,安装简单,使用方便,拉出一头,对孙某说“大虾,顺手拉兄弟一把……”,于是把绳子系在沟两边的绿化树木上,踩着钢丝就过了沟。刚刚站稳就四方作揖,“小生这里有礼了”。这时一戴着黄袖圈的老太太跳了出来,抓住钱某,“破坏绿化树木,罚款XXXX元,交钱,交钱,交钱!”(老人家作双枪老太婆怒视伪军状
……钱某被逼无奈,只好边掏钱,边对着后台叫道“导演,我这可是因公牺牲,不给个烈士称号也得报销”,后台一个臭鸡蛋飞出,“叫什么叫,我这个月的粮饷还不知哪里去领呢,都什么时代了,你不下岗都不错了……”)
  李某看着刚刚好不容易从台湾拖回来的“铝条.ZIP”

--------------------------------- 原创文章 By
实现和语言
---------------------------------

posted @ 2013-05-28 23:18  xinyuyuanm  阅读(2965)  评论(0编辑  收藏  举报