【Linux 编程基础】makefile的综合应用-实例

问题

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
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值