今天给各位分享方格路径c语言算法的知识,其中也会对方格路径条数算法进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
1、C语言,求解方格形路网中,点A到点B最短路径。请求大神帮助,谢谢!非诚勿扰2、一个6×7的方格,中间有3个点,坐标【3,6】【2,1】【4,7】。C语言打出每个方格距离这3点的最短的那个距离3、数据结构与算法作业:用C语言编程随机生成一个迷宫,然后找出从入口到出口的路线图。急!4、C语言题(方格取数)5、一道C语言棋盘最优路径的题目,求教6、C语言用图的广度优先遍历做漫步迷宫问题
C语言,求解方格形路网中,点A到点B最短路径。请求大神帮助,谢谢!非诚勿扰
#includestdio.h
int n;
int cnt=0;
char footprint[20];
void move(int row, int column)
{
if(row==ncolumn==n)
{
cnt++;
int i;
for(i=0;i2*n;i++)
footprint[i]==’d’?printf(“下”):printf(“右”);
printf(“\n”);
return;
}
if(rown)
{
footprint[row+column]=’d’;
move(row+1,column);
}
if(columnn)
{
footprint[row+column]=’l’;
move(row,column+1);
}
}
int main()
{
scanf(“%d”,n);
move(0,0);
printf(“共有%d种走法。\n”,cnt);
}
一个6×7的方格,中间有3个点,坐标【3,6】【2,1】【4,7】。C语言打出每个方格距离这3点的最短的那个距离
【程序1】题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?1.程序分析:可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去掉不满足条件的排列。2.程序源代码:main(){inti,j,k;printf(“\n“);for(i=1;i〈5;i++)/*以下为三重循环*/ for(j=1;j〈5;j++) for(k=1;k〈5;k++) {if(i!=ki!=jj!=k) /*确保i、j、k三位互不相同*/printf(“%d,%d,%d\n“,i,j,k); }}==============================================================【程序2】题目:企业发放的奖金根据利润提成。利润(I)低于或等于10万元时,奖金可提10%;利润高 于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提 成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于 40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于 100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?1.程序分析:请利用数轴来分界,定位。注意定义时需把奖金定义成长整型。2.程序源代码:main(){longinti;intbonus1,bonus2,bonus4,bonus6,bonus10,bonus;scanf(“%ld“,i);bonus1=100000*0.1;bonus2=bonus1+100000*0.75;bonus4=bonus2+200000*0.5;bonus6=bonus4+200000*0.3;bonus10=bonus6+400000*0.15; if(i〈=100000)bonus=i*0.1; elseif(i〈=200000) bonus=bonus1+(i-100000)*0.075;elseif(i〈=400000)bonus=bonus2+(i-200000)*0.05; elseif(i〈=600000) bonus=bonus4+(i-400000)*0.03;elseif(i〈=1000000)bonus=bonus6+(i-600000)*0.015; elsebonus=bonus10+(i-1000000)*0.01;printf(“bonus=%d“,bonus);}==============================================================【程序3】题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?1.程序分析:在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后的结果满足如下条件,即是结果。请看具体分析:2.程序源代码:#include“math.h“main(){longinti,x,y,z;for(i=1;i〈100000;i++) {x=sqrt(i+100);/*x为加上100后开方后的结果*/y=sqrt(i+268);/*y为再加上168后开方后的结果*/ if(x*x==i+100y*y==i+268)/*如果一个数的平方根的平方等于该数,这说明此数是完全平方数*/printf(“\n%ld\n“,i); }}==============================================================【程序4】题目:输入某年某月某日,判断这一天是这一年的第几天?1.程序分析:以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊情况,闰年且输入月份大于3时需考虑多加一天。2.程序源代码:main(){intday,month,year,sum,leap;printf(“\npleaseinputyear,month,day\n“);scanf(“%d,%d,%d“,year,month,day);switch(month)/*先计算某月以前月份的总天数*/{ case1:sum=0;break; case2:sum=31;break; case3:sum=59;break; case4:sum=90;break; case5:sum=120;break; case6:sum=151;break; case7:sum=181;break; case8:sum=212;break; case9:sum=243;break; case10:sum=273;break; case11:sum=304;break; case12:sum=334;break; default:printf(“dataerror“);break;}sum=sum+day; /*再加上某天的天数*/ if(year%400==0||(year%4==0year%100!=0))/*判断是不是闰年*/leap=1; elseleap=0;if(leap==1month〉2)/*如果是闰年且月份大于2,总天数应该加一天*/sum++;printf(“Itisthe%dthday.“,sum);}==============================================================【程序5】题目:输入三个整数x,y,z,请把这三个数由小到大输出。1.程序分析:我们想法把最小的数放到x上,先将x与y进行比较,如果x〉y则将x与y的值进行交换,然后再用x与z进行比较,如果x〉z则将x与z的值进行交换,这样能使x最小。2.程序源代码:main(){intx,y,z,t;scanf(“%d%d%d“,x,y,z);if(x〉y){t=x;x=y;y=t;}/*交换x,y的值*/if(x〉z){t=z;z=x;x=t;}/*交换x,z的值*/if(y〉z){t=y;y=z;z=t;}/*交换z,y的值*/printf(“smalltobig:%d%d%d\n“,x,y,z);}==============================================================【程序6】题目:用*号输出字母C的图案。1.程序分析:可先用’*’号在纸上写出字母C,再分行输出。2.程序源代码:#include“stdio.h“main(){printf(“HelloC-world!\n“);printf(“****\n“);printf(“*\n“);printf(“*\n“);printf(“****\n“);}==============================================================【程序7】题目:输出特殊图案,请在c环境中运行,看一看,VeryBeautiful!1.程序分析:字符共有256个。不同字符,图形不一样。2.程序源代码:#include“stdio.h“main(){chara=176,b=219;printf(“%c%c%c%c%c\n“,b,a,a,a,b);printf(“%c%c%c%c%c\n“,a,b,a,b,a);printf(“%c%c%c%c%c\n“,a,a,b,a,a);printf(“%c%c%c%c%c\n“,a,b,a,b,a);printf(“%c%c%c%c%c\n“,b,a,a,a,b);}==============================================================【程序8】题目:输出9*9口诀。1.程序分析:分行与列考虑,共9行9列,i控制行,j控制列。2.程序源代码:#include“stdio.h“main(){ inti,j,result; printf(“\n“); for(i=1;i〈10;i++){for(j=1;j〈10;j++){ result=i*j; printf(“%d*%d=%-3d“,i,j,result);/*-3d表示左对齐,占3位*/} printf(“\n“);/*每一行后换行*/}}==============================================================【程序9】题目:要求输出国际象棋棋盘。1.程序分析:用i控制行,j来控制列,根据i+j的和的变化来控制输出黑方格,还是白方格。2.程序源代码:#include“stdio.h“main(){inti,j;for(i=0;i〈8;i++) {for(j=0;j〈8;j++) if((i+j)%2==0)printf(“%c%c“,219,219); elseprintf(““); printf(“\n“); }}==============================================================【程序10】题目:打印楼梯,同时在楼梯上方打印两个笑脸。1.程序分析:用i控制行,j来控制列,j根据i的变化来控制输出黑方格的个数。2.程序源代码:#include“stdio.h“main(){inti,j;printf(“\1\1\n“);/*输出两个笑脸*/for(i=1;i〈11;i++) { for(j=1;j〈=i;j++)printf(“%c%c“,219,219); printf(“\n“); }}【程序11】题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月 后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?1.程序分析: 兔子的规律为数列1,1,2,3,5,8,13,21.2.程序源代码:main(){longf1,f2;inti;f1=f2=1;for(i=1;i〈=20;i++) {printf(“%12ld%12ld“,f1,f2); if(i%2==0)printf(“\n“);/*控制输出,每行四个*/ f1=f1+f2;/*前两个月加起来赋值给第三个月*/ f2=f1+f2;/*前两个月加起来赋值给第三个月*/ }}==============================================================【程序12】题目:判断101-200之间有多少个素数,并输出所有素数。1.程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。2.程序源代码:#include“math.h“main(){ intm,i,k,h=0,leap=1; printf(“\n“); for(m=101;m〈=200;m++){k=sqrt(m+1); for(i=2;i〈=k;i++) if(m%i==0){leap=0;break;} if(leap){printf(“%-4d“,m);h++;if(h%10==0)printf(“\n“); } leap=1;} printf(“\nThetotalis%d“,h);}==============================================================【程序13】题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数 本身。例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。2.程序源代码:main(){inti,j,k,n;printf(“’waterflower’numberis:“); for(n=100;n〈1000;n++) {i=n/100;/*分解出百位*/j=n/10%10;/*分解出十位*/k=n%10;/*分解出个位*/if(i*100+j*10+k==i*i*i+j*j*j+k*k*k) { printf(“%-5d“,n); } }printf(“\n“);}==============================================================【程序14】题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。(2)如果n〈〉k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n, 重复执行第一步。(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。2.程序源代码:/*zhengintisdividedyinshu*/main(){intn,i;printf(“\npleaseinputanumber:\n“);scanf(“%d“,n);printf(“%d=“,n);for(i=2;i〈=n;i++) {while(n!=i){ if(n%i==0) {printf(“%d*“,i);n=n/i; } elsebreak;}}printf(“%d“,n);}==============================================================【程序15】题目:利用条件运算符的嵌套来完成此题:学习成绩〉=90分的同学用A表示,60-89分之间的用B表示, 60分以下的用C表示。1.程序分析:(a〉b)?a:b这是条件运算符的基本例子。2.程序源代码:main(){ intscore; chargrade; printf(“pleaseinputascore\n“); scanf(“%d“,score); grade=score〉=90?’A’:(score〉=60?’B’:’C’); printf(“%dbelongsto%c“,score,grade);}==============================================================【程序16】题目:输入两个正整数m和n,求其最大公约数和最小公倍数。1.程序分析:利用辗除法。2.程序源代码:main(){ inta,b,num1,num2,temp; printf(“pleaseinputtwonumbers:\n“); scanf(“%d,%d“,num1,num2); if(num1 {temp=num1;num1=num2; num2=temp; }a=num1;b=num2;while(b!=0)/*利用辗除法,直到b为0为止*/ {temp=a%b;a=b;b=temp; }printf(“gongyueshu:%d\n“,a);printf(“gongbeishu:%d\n“,num1*num2/a);}==============================================================【程序17】题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。1.程序分析:利用while语句,条件为输入的字符不为’\n’.2.程序源代码:#include“stdio.h“main(){charc; intletters=0,space=0,digit=0,others=0; printf(“pleaseinputsomecharacters\n“); while((c=getchar())!=’\n’) { if(c〉=’a’c〈=’z’||c〉=’A’c〈=’Z’)letters++; elseif(c==’’)space++; elseif(c〉=’0’c〈=’9’) digit++; else others++;}printf(“allinall:char=%dspace=%ddigit=%dothers=%d\n“,letters,space,digit,others);}==============================================================【程序18】题目:求s=a+aa+aaa+aaaa+aaa的值,其中a是一个数字。例如2+22+222+2222+22222(此时 共有5个数相加),几个数相加有键盘控制。1.程序分析:关键是计算出每一项的值。2.程序源代码:main(){ inta,n,count=1; longintsn=0,tn=0; printf(“pleaseinputaandn\n“); scanf(“%d,%d“,a,n); printf(“a=%d,n=%d\n“,a,n); while(count〈=n) {tn=tn+a;sn=sn+tn;a=a*10;++count; }printf(“a+aa+=%ld\n“,sn);}==============================================================【程序19】题目:一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3.编程 找出1000以内的所有完数。1.程序分析:请参照程序〈–上页程序14.2.程序源代码:main(){staticintk[10];inti,j,n,s;for(j=2;j〈1000;j++) { n=-1; s=j;for(i=1;i{ if((j%i)==0) { n++;s=s-i;k[n]=i; }} if(s==0) { printf(“%disawanshu“,j); for(i=0;i printf(“%d,“,k); printf(“%d\n“,k[n]); }}}==============================================================【程序20】题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在 第10次落地时,共经过多少米?第10次反弹多高?1.程序分析:见下面注释2.程序源代码:main(){floatsn=100.0,hn=sn/2;intn;for(n=2;n〈=10;n++) {sn=sn+2*hn;/*第n次落地时共经过的米数*/hn=hn/2;/*第n次反跳高度*/ }printf(“thetotalofroadis%f\n“,sn);printf(“thetenthis%fmeter\n“,hn);}
数据结构与算法作业:用C语言编程随机生成一个迷宫,然后找出从入口到出口的路线图。急!
几点说明:
1.本程序是动态的,运行后自动寻找迷宫出路
2.本程序对C语言刚学完的有很大的意义.
3.四周是墙,坐标(1,1)是入口,右下脚是出口
声明:本程序用VC调试是无法通过的需要修改
本程序调试工具是TC…………………
#include “graphics.h”
#include “dos.h”
#include “stdlib.h”
#include “process.h”
#define MAX_COL 14/*定义迷宫大小*/
#define MAX_ROW 14
typedef struct
{ int vert;
int horiz;
}offsets;
mapture(int i,int j,int k);/*标记迷宫,(i,j)标记为k模式*/
initmaze();/*初始化迷宫数组*/
findmaze(int i,int j);/*找到了(i,j)可走,标记*/
mapmaze();/*画出原始迷宫*/
int findpath(int row,int col);/*递归函数,找出迷宫路径*/
mapbar();/*画出方格*/
initgrap();/*初始化VGA*/
print();/*迷宫走完后,输出是否成功 */
int startx=50,starty=50;/*画图的屏幕坐标*/
int maze[MAX_ROW][MAX_COL];
offsets move[8]={{0,1},{1,1},{-1,1},{1,0},{-1,0},{0,-1},{1,-1},{-1,-1}}; /*8个方向寻找*/
initmaze()/*初始化迷宫数组 */
{ int i,j;
for(i=0;iMAX_ROW;i++)/*迷宫四周设置为1 代表墙*/
{ maze[i][0]=1;
maze[i][MAX_COL-1]=1;
}
for(i=0;iMAX_COL;i++)
{ maze[0][i]=1;
maze[MAX_ROW-1][i]=1;
}
randomize();
for(i=1;iMAX_ROW-1;i++)/*迷宫图形随机产生 1表示不通 0表示可行*/
for(j=1;jMAX_COL-1;j++)
{
maze[i][j]=random(2);
}
}
findmaze(int i,int j)/*找到 (i,j)可走*/
{
mapture(j,i,2);/*在图形上标记*/
sleep(1);
}
returnmaze(int i,int j)/*找到(i,j)可走 ,但下一步无路走则标记*/
{
mapture(j,i,3);/*在图形上标记*/
sleep(1);
}
print(int i)/*迷宫走完后,输出是否成功*/
{ settextstyle(1,0,5);
if(i==1)
outtextxy(340,400,”Ture path!”);
else if(i==2)
outtextxy(340,400,”No path!”);
}
int findpath(int row,int col)/*用递归法找迷宫*/
{ int direct,next_row,next_col;
direct=0;
maze[1][1]=2;
mapture(1,1,2);
sleep(1);
while(direct8)/*8个方向寻找*/
{ next_row=row+move[direct].vert;/*设置下一步坐标*/
next_col=col+move[direct].horiz;
if(maze[next_row][next_col]==0) /*可走,便标记*/
{ maze[next_row][next_col]=2;
findmaze(next_row,next_col) ;
if(next_row==(MAX_ROW-2)next_col==(MAX_COL-2))/*找到出口退出程序*/
{ print(1);
getch();
exit(0);
}
else
findpath(next_row,next_col);/*没有到出口继续递归*/
maze[next_row][next_col]=3;
returnmaze(next_row,next_col);
}
direct++;
}
return(row);
}
TC调试良好
C语言题(方格取数)
/*
方格取数(grid.cpp)
问题描述:
给一个n行m列的网格,每个格子里都有一个整数(正负任意),每一步只能向下或向右:
向下一次只能走一格;但是如果向右走,则每次可以走一格或者走到该行的列数是当前所在列数倍数的格子,
即:如果当前格子是(x,y),下一步可以是(x+1,y),(x,y+1)或者(x,y*k) 其中k1。
编程计算从左上角(1,1)走到右下角(n,m)所经过的格子的数字和的最大值。
输入格式:
第一行为两个整数n和m(1≤n≤20,10≤m≤1000),表示网格大小;
接下来n行,每行m个整数,表示对应格子里的整数ti(|ti|100)。
输出格式:
仅一个整数,表示最大和值。
Author:Im_hear
*/
#includeiostream
#includecstring
#includecmath
using namespace std;
int N,M;
int map[21][1001]={0};
int ans[21][1001]={0};
int factor[1001][33]={0};
int fun(int row);
int init(int row);
int main()
{
int x,y;
scanf(“%d%d”,N,M);
init(N);
for(x=1;x=N;++x){
for(y=1;y=M;++y){
scanf(“%d”,map[x][y]);
}
}
for(x=1;x=N;++x){
//理解为输入的矩阵只有一行
fun(x);
}
printf(“%d\n”,ans[N][M]);
return 0;
}
/*将第row行每个位置能达到的最大值记录到ans[row][]行中*/
int fun(int row)
{
int i,index,y,step=1,maxPre,iCount;
int temp = 0;
//第一列只能从上行过来
ans[row][1] = ans[row-1][1] + map[row][1];
for(y=2;y=M;++y){
//假设从左边过来时,累加的值最大
maxPre = ans[row][y-1];
if(row1 ans[row-1][y]maxPre){
//假设从上边过来时,累加的值最大
maxPre = ans[row-1][y];
}
//取得y的因数个数
iCount = factor[row][0];
for(i=1;i=iCount;++i){
//取得y的第i个因数
index = factor[row][i];
//比原先更好的路线,从(row,factor[row][i])位置过来
if(ans[row][index] maxPre){
maxPre = ans[row][index];
}
}
//更新当前位置的最大累计值
ans[row][y] = maxPre + map[row][y];
}
/*
//去掉注释可以看到每行的变化
for(y=1;y=M;++y){
printf(“%3d, “,ans[row][y]);
}
printf(“\n”);
*/
return 0;
}
/*储存1000内每个数的因数*/
int init(int row)
{
int x,y,icount,step;
factor[1][1] = 1;
for(x=2;x=row;++x){
icount=1;
//x是奇数时,因数都是奇数,步长可设为2
step = x1?2:1;
y = x1?1:2;
for(;y=x/2;y+=step){
if(x%y == 0){
factor[x][icount++] = y;
}
}
factor[x][0] = icount-1;
}
return 0;
}
一道C语言棋盘最优路径的题目,求教
这题还是有点意思的。
正如diordna所说,因为涉及到全局最优,
大小又是1000×1000,感觉广搜有点困难,所以打算试试DP。。
思路如下,不知道对不对。。
Part.1
设map[i][j]保存棋盘格子的价值 (i = 0..n-1, j = 0..m-1)
设f[i][j][k]记录棋盘(i, j)位置的最大价值和 (i = 0..n-1, j = 0..m-1, k = 0,1,2)
k表示这个位置是怎么来的:
k = 0: 左→右
k = 1: 上→下
k = 2: 下→上
首先初始化 f[i][j][k] = -inf
然后根据题意有:f[0][0][k] = map[0][0], k = 0,1,2
Part.2
又因为不能向左走,实际上就是说第j = 0列的格子只能向下走
所以可以先把f[i][0][1]算出来
f[i][0][1] = max(k=0,1){f[i-1][0][k]} + map[0][j] = f[i-1][0][1] + map[i][0], i = 1..n-1
Part.3
然后考虑任意一个非第0列的格子(i, j), i = 0..n-1, j = 1..m-1
便于思考特殊化一下,假设考虑第j = 1列(当然其它列也一样),
任意一个格子有3种到达方式,分别对应k = 0, 1, 2
但此时我们只知道每个格子的左边格子里的f值
那么我们先计算k=0时刻各格子的f值 (左→右)
f[i][j][0] = max(k=0,1,2){f[i][j-1][k]} + map[i][j], i = 0..n-1, j = 1
Part.4
这样一来各个格子从左边来到后的总价值f就得到了
接下来处理从上到下和从下到上的情况
由于从某个格子开始一旦选择从上到下或从下到上走后就无法回头了
不妨从上到下开始:
f[i][j][1] = max(k=0,1){f[i-1][j][k]} + map[i][j], i = 1..n-1, j = 1
然后从下到上:
f[i][j][2] = max(k=0,2){f[i+1][j][k]} + map[i][j], i = n-2..0, j = 1
Part.5
这样一来每个格子对应的3种走法的价值最大值就能得到了
如此回到Part.3循环列j = 1..m-1
最后只要取max(k=0,1){f[n-1][m-1][k]} 即可得到最优路径价值和
试着写了一下,不知道能不能过。。
注意由于开了1000×1000的long数组,所以VC调试的时候注意把堆栈开大一点
#include iostream
using namespace std;
#define MAXN 1000
#define INF 0x7fffffff
long map[MAXN][MAXN];
long f[MAXN][MAXN][3];
long getmax(long a, long b){ return (a b) ? a : b;}
void init()
{
for(int i = 0; i MAXN; i++)
{
for(int j = 0; j MAXN; j++)
{
map[i][j] = -INF;
f[i][j][0] = -INF;
f[i][j][1] = -INF;
f[i][j][2] = -INF;
}
}
}
int main()
{
// Part.1
int n, m;
cin n m;
init();
for(int i=0; in; i++)
{
for(int j=0; jm; j++)
{
cin map[i][j];
}
}
f[0][0][0] = f[0][0][1] = f[0][0][2] = map[0][0];
// Part.2
for(int i=1; in; i++)
{
f[i][0][1] = f[i-1][0][1] + map[i][0];
}
for(int j=1; jm; j++)
{
// Part.3
for(int i=0; in; i++)
{
long max = getmax(getmax(f[i][j-1][0], f[i][j-1][1]), f[i][j-1][2]);
if(max == -INF) continue;
f[i][j][0] = max + map[i][j];
}
// Part.4
for(int i=1; in; i++)
{
long max = getmax(f[i-1][j][0], f[i-1][j][1]);
if(max == -INF) continue;
f[i][j][1] = max + map[i][j];
}
for(int i=n-2; i=0; i–)
{
long max = getmax(f[i+1][j][0], f[i+1][j][2]);
if(max == -INF) continue;
f[i][j][2] = max + map[i][j];
}
}
cout getmax(f[n-1][m-1][0], f[n-1][m-1][1]) endl;
return 0;
}
C语言用图的广度优先遍历做漫步迷宫问题
这是我们老师给我们上数据结构课的课件
#include “stdio.h”
typedef int datatype; /*假定线性表元素的类型为整型*/
#define maxsize 1024 /*假定线性表的最大长度为1024*/
# define n 100 /* 图的顶点最大个数 */
typedef char VEXTYPE; /* 顶点的数据类型 */
typedef float ADJTYPE; /* 权值类型 */
typedef struct
{ VEXTYPE vexs[n] ; /* 顶点信息数组 */
ADJTYPE arcs[n][n] ; /* 边权数组 */
int num ; /* 顶点的实际个数 */
}GRAPH;
/***********************1。置空图**********************/
void GraphInit(GRAPH *L)
{
L-num=0;
}
/***********************2。求结点数**********************/
int GraphVexs(GRAPH *L)
{
return(L-num);
}
/***********************3。创建图**********************/
void GraphCreate(GRAPH *L)
{
int i,j;
GraphInit(L);
printf(“请输入顶点数目:”);
scanf(“%d”,L-num);
printf(“请输入各顶点的信息(单个符号):”);
for(i=0;iL-num;i++)
{
fflush(stdin);
scanf(“%c”,L-vexs[i]);
}
printf(“请输入边权矩阵的信息:”);
for(i=0;iL-num;i++)
{
for(j=0;jL-num;j++)
{
scanf(“%f”,L-arcs[i][j]);
}
}
printf(“图已经创建完毕!”);
}
/***********************4。图的输出**********************/
void GraphOut(GRAPH L)
{
int i,j;
printf(“\n图的顶点数目为:%d”,L.num);
printf(“\n图的各顶点的信息为:\n”);
for(i=0;iL.num;i++)
printf(“%c “,L.vexs[i]);
printf(“\n图的边权矩阵的信息为:\n”);
for(i=0;iL.num;i++)
{
for(j=0;jL.num;j++)
{
printf(“%6.2f “,L.arcs[i][j]);
}
printf(“\n”);
}
printf(“图已经输出完毕!”);
}
/***********************5。图的深度周游**********************/
void DFS(GRAPH g,int qidian,int mark[])
//从第qidian个点出发深度优先周游图g中能访问的各个顶点
{
int v1;
mark[qidian]=1;
printf(“%c “,g.vexs[qidian]);
for(v1=0;v1g.num;v1++)
{
if(g.arcs[qidian][v1]!=0mark[v1]==0)
DFS(g,v1,mark);
}
}
/***********************6。图的深度周游**********************/
void GraphDFS(GRAPH g)
//深度优先周游图g中能访问的各个顶点
{
int qidian,v,v1,mark[maxsize];
printf(“\n深度周游:”);
printf(“\n请输入起点的下标:”);
scanf(“%d”,qidian);
for(v=0;vg.num;v++)
{
mark[v]=0;
}
for(v=qidian;vg.num+qidian;v++)
{
//printf(“v=%d “,v);
v1=v%g.num;
if(mark[v1]==0)
DFS(g,v1,mark);
}
}
typedef int DATATYPE; //队列元素的数据类型
typedef struct
{
DATATYPE data[maxsize]; //队中元素
int front,rear; //队头元素下标、队尾元素后面位置的下标
} SEQQUEUE;
/*****************************************************************************/
void QueueInit(SEQQUEUE *sq)
//将顺序循环队列sq置空(初始化)
{
sq-front=0;
sq-rear=0;
}
/*****************************************************************************/
int QueueIsEmpty(SEQQUEUE sq)
//如果顺序循环队列sq为空,成功返回1,否则返回0
{
if (sq.rear==sq.front)
return(1);
else
return(0);
}
/*****************************************************************************/
int QueueFront(SEQQUEUE sq,DATATYPE *e)
//将顺序循环队列sq的队头元素保存到e所指地址,成功返回1,失败返回0
{
if (QueueIsEmpty(sq))
else
}
/*****************************************************************************/
int QueueIn (SEQQUEUE *sq,DATATYPE x)
//将元素x入队列sq的队尾,成功返回1,失败返回0
{
if (sq-front==(sq-rear+1)%maxsize)
{
printf(“queue is full!\n”);
return 0;
}
else
{
sq-data[sq-rear]=x;
sq-rear=(sq-rear+1)%maxsize;
return(1);
}
}
/*****************************************************************************/
int QueueOut(SEQQUEUE *sq)
//将队列sq队首元素出队列,成功返回1,失败返回0
{
if (QueueIsEmpty(*sq))
{
printf(“queue is empty!\n”);
return 0;
}
else
{
sq-front=(sq-front+1)%maxsize;
return 1;
}
}
/***********************7。图的广度周游**********************/
void BFS(GRAPH g,int v,int mark[])
//从v出发广度优先周游图g中能访问的各个顶点
{
int v1,v2;
SEQQUEUE q;
QueueInit(q);
QueueIn(q,v);
mark[v]=1;
printf(“%c “,g.vexs[v]);
while(QueueIsEmpty(q)==0)
{
QueueFront(q,v1);
QueueOut(q);
for(v2=0;v2g.num;v2++)
{
if(g.arcs[v1][v2]!=0mark[v2]==0)
{
QueueIn(q,v2);
mark[v2]=1;
printf(“%c “,g.vexs[v2]);
}
}
}
}
/***********************8。图的广度周游**********************/
void GraphBFS(GRAPH g)
//深度优先周游图g中能访问的各个顶点
{
int qidian,v,v1,mark[maxsize];
printf(“\n广度周游:”);
printf(“\n请输入起点的下标:”);
scanf(“%d”,qidian);
for(v=0;vg.num;v++)
{
mark[v]=0;
}
for(v=qidian;vg.num+qidian;v++)
{
v1=v%g.num;
if(mark[v1]==0)
BFS(g,v1,mark);
}
}
/***********************主函数**********************/
void main()
{
GRAPH tu;
GraphCreate(tu);
GraphOut(tu);
GraphDFS(tu);
GraphBFS(tu);
}
关于方格路径c语言算法和方格路径条数算法的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。