方格路径c语言算法(方格路径条数算法)

今天给各位分享方格路径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);

}

方格路径c语言算法(方格路径条数算法)

一个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语言算法和方格路径条数算法的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

本文来自投稿,不代表【】观点,发布者:【

本文地址: ,如若转载,请注明出处!

举报投诉邮箱:253000106@qq.com

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2024年3月30日 16:39:45
下一篇 2024年3月30日 16:48:04

相关推荐

  • javasocket编程,Java socket编程中,禁用nagle算法的参数

    Java进行并发多连接socket编程 1、Java可利用ServerSocket类对外部客户端提供多个socket接口。基本的做法是先创建一个ServerSocket实例,并绑定一个指定的端口,然后在这个实例上调用accept()方法等待客户端的连接请求。 2、Socket socket=server.accept(0;Thread handleThrea…

    2024年5月23日
    4600
  • dh算法c语言实现,c语言算法有哪些

    云计算时代安全综述-秘钥交换(上) 1、在加密密钥管理方面,应采用集中化的用户密钥管理与分发机制,实现对用户信息存储的高效安全管理与维护。 2、在云计算中,确保私有数据安全性的最佳方法之一就是对传输的数据和存储的数据进行加密处理。当谈及云计算服务时,仍然存在一些加密方面的潜在问题。 3、第七大安全威胁是云服务滥用,比如坏人利用云服务破解普通计算机很难破解的加…

    2024年5月23日
    4200
  • c语言算法分析是什么,c语言算法的作用

    C语言算法详解 1、C语言大牛雅荐的七大经典排序算法 冒泡排序 比较相邻的元素。 2、c语言中的算法是指:一系列解决问题的清晰指令,用系统的方法描述解决问题的策略机制。也就是说,能够对一定规范的输入,在有限时间内获得所要求的输出。通俗说就是解决问题的方法和步骤。 3、) 贪婪算法 贪婪算法可以获取到问题的局部最优解,不一定能获取到全局最优解,同时获取最优解的…

    2024年5月23日
    3500
  • java获取项目上传路径,java获取项目根路径

    java获取当前项目的路径 在jsp里,根目录是WebRoot 在class文件中,根目录是WebRoot/WEB-INF/classes 也可以选用System.getProperty(user.dir)获取工程的绝对路径。 getClass().getResource() 方法获得相对路径( 此方法在jar包中无效。 File类有两个常用方法可以得到文件…

    2024年5月23日
    4200
  • c语言实现优先级调度算法,c语言运算符表

    有c语言模拟调度算法吗? 1、调度算法的实施过程如下所述:(1)应设置多个就绪队列,并为各个队列赋予不同的优先级。(2)当一个新进程进入内存后,首先将它放入第一队列的末尾,按FCFS的原则排队等待调度。 2、实验内容 设计一个时间片轮转调度算法实现处理机调度的程序。 3、操作系统进程调度算法模拟 使用链表数据结构,用C语言写一个用优先级算法的进程调度,进程每…

    2024年5月23日
    4300
  • java音乐文件打入jar包后找不到路径,java在打包成jar后找不到类

    java程序在Eclipse中运行没有问题,打包成.jar文件之后运行后路径出现… 可能jar文件损坏了,你可以尝试用winrar打开这个jar文件,把它解压,看有没有报错,如果报错,说明文件损坏了。打包成jar文件后运行出现Invalid or corrupt jarfile 解决打jar包 1。jar -cvf hello。jar hello…

    2024年5月23日
    4300
  • c语言打开目录下文件,c语言打开指定路径的文件

    c语言中由用户给出一个文件夹,如何依次打开文件夹中的每个文件? 1、用文件路径操作函数找到源代码所在的文件夹。使用文件操作函数fopen打开源文件即可。路径操作函数 chdir。chdir函数是C语言中的一个系统调用函数(同cd)功 能:更改当前工作目录。参 数:Path 必选。Path 可能包含驱动器。 2、先把各个文件都存储(即合并)在一个 字符数组 里…

    2024年5月23日
    3600
  • linux命令行不显示路径,linux 不显示路径

    linux查看路径命令 linux命令如果记不得,可以使用man命令来查看某个命令的使用。 find命令需要你给出想搜索的目录;指定搜索属性选项,例如,-name用于指定区分大小写的文件名;然后是搜索字符串。 linux查找文件路径,为您提供linux查找文件路径图文信息,打开linux系统,在linux的桌面的空白处右击。在弹出的下拉选项里,点击打开终端。…

    2024年5月23日
    4800
  • javatea算法,java算法是什么意思

    TEA加密算法的应用 1、交织算法消息被分为多个加密单元,每一个加密单元都是8字节,使用TEA进行加密,加密结果与下一个加密单元做异或运算后再作为待加密的明文。 2、tea算法在安全学领域,TEA(Tiny Encryption Algorithm)是一种分组加密算法,它的实现非常简单,通常只需要很精短的几行代码。TEA 算法最初是由剑桥计算机实验室的 Da…

    2024年5月23日
    4100
  • java常考算法,java算法基础题

    大学java中都学过哪些经典算法?请学过的朋友解答下 Java SE部分 初级语法,面向对象,异常,IO流,多线程,Java Swing,JDBC,泛型,注解,反射等。数据库部分,基础的sql语句,sql语句调优,索引,数据库引擎,存储过程,触发器,事务等。 互联网行业目前还是最热门的行业之一,许多想入行互联网的人都会选择Java学习,发展前景非常好,普通人…

    2024年5月23日
    3900

发表回复

登录后才能评论



关注微信