c语言求最大公约数最简单的方法?
求最大公约数的简单方法就是,看看这几个数有没有共同的约数,怎么来确定呢?
首先我们要知道能被235整除数的特征,还就是有这个数不具备有235整除数的特征,有些特殊数,比如11 13 17 19这几个数的特征就可以解决求最大公约数的题型了,最大公约数就是这几个数所有的约数的乘积,就是这个数的最大公约数,回答完毕
c语言贪吃蛇代码及解析?
#include<stdio.h>
#include<time.h>
#include<windows.h>
#include<stdlib.h>
#define U 1
#define D 2
#define L 3
#define R 4 //蛇的状态,U:上 ;D:下;L:左 R:右
typedef struct SNAKE //蛇身的一个节点
{
int x;
int y;
struct SNAKE *next;
}snake;
//全局变量//
int score=0,add=10;//总得分与每次吃食物得分。
int status,sleeptime=200;//每次运行的时间间隔
snake *head, *food;//蛇头指针,食物指针
snake *q;//遍历蛇的时候用到的指针
int endgamestatus=0; //游戏结束的情况,1:撞到墙;2:咬到自己;3:主动退出游戏。
//声明全部函数//
void Pos();
void creatMap();
void initsnake();
int biteself();
void createfood();
void cantcrosswall();
void snakemove();
void pause();
void gamecircle();
void welcometogame();
void endgame();
void gamestart();
void Pos(int x,int y)//设置光标位置
{
COORD pos;
HANDLE hOutput;
pos.X=x;
pos.Y=y;
hOutput=GetStdHandle(STD_OUTPUT_HANDLE);
SetConsoleCursorPosition(hOutput,pos);
}
void creatMap()//创建地图
{
int i;
for(i=0;i<58;i+=2)//打印上下边框
{
Pos(i,0);
printf(“■”);
Pos(i,26);
printf(“■”);
}
for(i=1;i<26;i++)//打印左右边框
{
Pos(0,i);
printf(“■”);
Pos(56,i);
printf(“■”);
}
}
void initsnake()//初始化蛇身
{
snake *tail;
int i;
tail=(snake*)malloc(sizeof(snake));//从蛇尾开始,头插法,以x,y设定开始的位置//
tail->x=24;
tail->y=5;
tail->next=NULL;
for(i=1;i<=4;i++)
{
head=(snake*)malloc(sizeof(snake));
head->next=tail;
head->x=24+2*i;
head->y=5;
tail=head;
}
while(tail!=NULL)//从头到为,输出蛇身
{
Pos(tail->x,tail->y);
printf(“■”);
tail=tail->next;
}
}
int biteself()//判断是否咬到了自己
{
snake *self;
self=head->next;
while(self!=NULL)
{
if(self->x==head->x && self->y==head->y)
{
return 1;
}
self=self->next;
}
return 0;
}
void createfood()//随机出现食物
{
snake *food_1;
srand((unsigned)time(NULL));
food_1=(snake*)malloc(sizeof(snake));
while((food_1->x%2)!=0) //保证其为偶数,使得食物能与蛇头对其
{
food_1->x=rand()%52+2;
}
food_1->y=rand()%24+1;
q=head;
while(q->next==NULL)
{
if(q->x==food_1->x && q->y==food_1->y) //判断蛇身是否与食物重合
{
free(food_1);
createfood();
}
q=q->next;
}
Pos(food_1->x,food_1->y);
food=food_1;
printf(“■”);
}
void cantcrosswall()//不能穿墙
{
if(head->x==0 || head->x==56 ||head->y==0 || head->y==26)
{
endgamestatus=1;
endgame();
}
}
void snakemove()//蛇前进,上U,下D,左L,右R
{
snake * nexthead;
cantcrosswall();
nexthead=(snake*)malloc(sizeof(snake));
if(status==U)
{
nexthead->x=head->x;
nexthead->y=head->y-1;
if(nexthead->x==food->x && nexthead->y==food->y)//如果下一个有食物//
{
nexthead->next=head;
head=nexthead;
q=head;
while(q!=NULL)
{
Pos(q->x,q->y);
printf(“■”);
q=q->next;
}
score=score+add;
createfood();
}
else //如果没有食物//
{
nexthead->next=head;
head=nexthead;
q=head;
while(q->next->next!=NULL)
{
Pos(q->x,q->y);
printf(“■”);
q=q->next;
}
Pos(q->next->x,q->next->y);
printf(” “);
free(q->next);
q->next=NULL;
}
}
if(status==D)
{
nexthead->x=head->x;
nexthead->y=head->y+1;
if(nexthead->x==food->x && nexthead->y==food->y) //有食物
{
nexthead->next=head;
head=nexthead;
q=head;
while(q!=NULL)
{
Pos(q->x,q->y);
printf(“■”);
q=q->next;
}
score=score+add;
createfood();
}
else //没有食物
{
nexthead->next=head;
head=nexthead;
q=head;
while(q->next->next!=NULL)
{
Pos(q->x,q->y);
printf(“■”);
q=q->next;
}
Pos(q->next->x,q->next->y);
printf(” “);
free(q->next);
q->next=NULL;
}
}
if(status==L)
{
nexthead->x=head->x-2;
nexthead->y=head->y;
if(nexthead->x==food->x && nexthead->y==food->y)//有食物
{
nexthead->next=head;
head=nexthead;
q=head;
while(q!=NULL)
{
Pos(q->x,q->y);
printf(“■”);
q=q->next;
}
score=score+add;
createfood();
}
else //没有食物
{
nexthead->next=head;
head=nexthead;
q=head;
while(q->next->next!=NULL)
{
Pos(q->x,q->y);
printf(“■”);
q=q->next;
}
Pos(q->next->x,q->next->y);
printf(” “);
free(q->next);
q->next=NULL;
}
}
if(status==R)
{
nexthead->x=head->x+2;
nexthead->y=head->y;
if(nexthead->x==food->x && nexthead->y==food->y)//有食物
{
nexthead->next=head;
head=nexthead;
q=head;
while(q!=NULL)
{
Pos(q->x,q->y);
printf(“■”);
q=q->next;
}
score=score+add;
createfood();
}
else //没有食物
{
nexthead->next=head;
head=nexthead;
q=head;
while(q->next->next!=NULL)
{
Pos(q->x,q->y);
printf(“■”);
q=q->next;
}
Pos(q->next->x,q->next->y);
printf(” “);
free(q->next);
q->next=NULL;
}
}
if(biteself()==1) //判断是否会咬到自己
{
endgamestatus=2;
endgame();
}
}
void pause()//暂停
{
while(1)
{
Sleep(300);
if(GetAsyncKeyState(VK_SPACE))
{
break;
}
}
}
void gamecircle()//控制游戏
{
Pos(64,15);
printf(“不能穿墙,不能咬到自己n”);
Pos(64,16);
printf(“用↑.↓.←.→分别控制蛇的移动.”);
Pos(64,17);
printf(“F1 为加速,F2 为减速n”);
Pos(64,18);
printf(“ESC :退出游戏.space:暂停游戏.”);
Pos(64,20);
printf(“c语言研究中心 www.dotcpp.com”);
status=R;
while(1)
{
Pos(64,10);
printf(“得分:%d “,score);
Pos(64,11);
printf(“每个食物得分:%d分”,add);
if(GetAsyncKeyState(VK_UP) && status!=D)
{
status=U;
}
else if(GetAsyncKeyState(VK_DOWN) && status!=U)
{
status=D;
}
else if(GetAsyncKeyState(VK_LEFT)&& status!=R)
{
status=L;
}
else if(GetAsyncKeyState(VK_RIGHT)&& status!=L)
{
status=R;
}
else if(GetAsyncKeyState(VK_SPACE))
{
pause();
}
else if(GetAsyncKeyState(VK_ESCAPE))
{
endgamestatus=3;
break;
}
else if(GetAsyncKeyState(VK_F1))
{
if(sleeptime>=50)
{
sleeptime=sleeptime-30;
add=add+2;
if(sleeptime==320)
{
add=2;//防止减到1之后再加回来有错
}
}
}
else if(GetAsyncKeyState(VK_F2))
{
if(sleeptime<350)
{
sleeptime=sleeptime+30;
add=add-2;
if(sleeptime==350)
{
add=1; //保证最低分为1
}
}
}
Sleep(sleeptime);
snakemove();
}
}
void welcometogame()//开始界面
{
Pos(40,12);
system(“title c语言研究中心 www.dotcpp.com”);
printf(“欢迎来到贪食蛇游戏!”);
Pos(40,25);
system(“pause”);
system(“cls”);
Pos(25,12);
printf(“用↑.↓.←.→分别控制蛇的移动, F1 为加速,2 为减速n”);
Pos(25,13);
printf(“加速将能得到更高的分数。n”);
system(“pause”);
system(“cls”);
}
void endgame()//结束游戏
{
system(“cls”);
Pos(24,12);
if(endgamestatus==1)
{
printf(“对不起,您撞到墙了。游戏结束.”);
}
else if(endgamestatus==2)
{
printf(“对不起,您咬到自己了。游戏结束.”);
}
else if(endgamestatus==3)
{
printf(“您的已经结束了游戏。”);
}
Pos(24,13);
printf(“您的得分是%dn”,score);
exit(0);
}
void gamestart()//游戏初始化
{
system(“mode con cols=100 lines=30”);
welcometogame();
creatMap();
initsnake();
createfood();
}
int main()
{
gamestart();
gamecircle();
endgame();
return 0;
}
c语言求两个整数最大公约数?
求两个数的最大公约数,首先我们要知道什么是最大公约数,就是把这两个数所有相同的约数乘积,这个积就是这两个数的最大公约数。
例如求18和72的最大公约数,首先用他们俩相同的约数3去除,(你要是直接看出来也行,不用从最小的质数去找,直接用72是18的倍数,那么他们俩的最大公约数是18),6和24,再用6去除这两个数,1和4所以他们的最大公约数是3 x6=18
c语言三个数的最大公约数怎么求?
如果三个数x,y,z的最大公约数是k,那么k一定能同时整除x,y,z,且k一定小于等于x,y,z中的最小数。据此,可以写出C语言程序段:
int min=x,i;
if(min>y)min=y;
if(min>z)min=z;
for(i=min;i>=1;i–)
{
if(x%i==0 && y%i==0 && z%i==0) break;
}
printf(“最大公约数是:%d”,i);
c语言求最大公约数程序用while?
#include<stdio.h> intmain(void) { inta,b,t; scanf(“%d%d”,&a,&b); while(a%b) { t=b; b=a%b; a=t; } printf(“%dn”,b); return0; }
c语言求最大约数?
c语言最大公约数的有三种求法:
穷举法(枚举法):
从两个数中较小数开始由大到小列举,直到找到公约数立即中断列举,得到的公约数便是最大公约数。
更相减损法:
Steps:任意给定两个正整数;判断它们是否都是偶数。若是,则用2约简;若不是则执行第二步。
C语言——求最大公约数和最小公倍数的简单程序?
首先我们输入两个整数m和n,小的数赋值给m,大的数给n。先找n的约数,用一个中间量i代替m,从i开始,如果n%i==0,则说明n,m的最大公约数就是m,否则执行第3步,i自减1,再执行n%i,判断n%i==0,如果是说明n能被i整除;执行第4步,否则再次执行第3步,判断m%i是否等于0,如果是说明n和m能同时被i整除,最大公约数为i;否则执行第3步,最小公倍数比较容易求,只要两数相乘,然后除以最大公约数就可以得到。
c语言求多个数最大公约数算法?
int i,a=3,b=6; int max=b; //初始化b大,下面判断如果a>b就把a给max //判断a,b大小 if(a>b) max=a; for(i=max;i>0;i–) //公约数肯定不大于两数中最大的,所以从最大的往下找,找到的第一个就是最大 { if(a%i==0 && b%i==0) { printf(“最大公约数%d”,i); break; //找到最大的就退出 } }