问题
1
模拟一个自动寻路机器人。
假设有一个10*10的网格地图,最左上角的坐标为(0,0),最右下角为(9,9),在左上角(0,0)坐标处生成机器人,机器人只有两个动作:向下走down()和向右走right()。每次随机生成一个终点(h,w),打印机器人从(0,0)走到(h,w)的路线(自己决定机器人的行走路线)。
例如:
随机生成的终点是(2,3)
输出(0,0),(0,1),(0,2),(0,3),(1,3),(2,3)
要求:
1)向右走写成一个函数放在right.c文件里,向下走写成一个函数放在down.c文件里,决定机器人下一步怎么走写成一个函数放在step.c文件里,打印最后结果写成main函数放在main.c文件里。
2)写一个makefile文件编译上面的程序(不写makefile为0分)。
解
main.c:
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include "step.h"
#include "types.h"
const int MAX_COORD = 10;
void walk(const struct coord _Src, const struct coord _Dest) {
struct coord c = _Src;
do {
printf("(%d, %d)\n", c.x, c.y);
} while (nextstep(&c, &_Dest) == FALSE);
}
int main() {
srand(time(NULL));
struct coord s = {
0, 0 };
struct coord d = {
rand() % MAX_COORD, rand() % MAX_COORD };
printf("Source: (%d, %d)\n", s.x, s.y);
printf("Destination: (%d, %d)\n", d