随机步法A-Z

程序是生成一个10X10的字符数组,初始化时全为 ‘.’  的随机步法。程序必须随机的从一个元素 ‘走到’ 另一个元素,每次只向上、向下、向左或向右移动一个元素位置。已访问过的元素按访问顺序用字母A到Z进行标记。

考察srand和rand的使用

代码不是太好,只能简单实现

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <time.h>

int main()
{
    char str[10][10];
    char point = 'A';
    int i,j,k,t;
    int randd;
    for(i=0; i<10; i++)
    {
        for(j=0; j<10; j++)
        {
            str[i][j] = '.';
        }
    }
    srand((unsigned)time(NULL));
    i = 0 ; j = 0;
    str[i][j] = 'A';
    while(point != 'Z')
    {
        randd = rand() % 4;
        if(randd == 0 && i-1 >= 0 && str[i-1][j] == '.')//判断条件
        {
            str[i-1][j] = ++point;
            i -= 1;
        }
        else if(randd == 1 && j+1 < 10 && str[i][j+1] == '.')
        {
            str[i][j+1] = ++point;
            j += 1;
        }
        else if(randd == 2 && i+1 < 10 && str[i+1][j] == '.')
        {
            str[i+1][j] = ++point;
            i +=1;
        }
        else if(randd == 3 && j-1 >= 0 && str[i][j-1] == '.')
        {
            str[i][j-1] = ++point;
            j -= 1;
        }
        else if(str[i-1][j] != '.' && str[i][j+1] != '.' && str[i+1][j] != '.' && str[i][j-1] != '.')
        {
            break;//通过边界测定,判断跳出情况
        }
        //else randd = rand() % 4;;
    }

    for(i=0; i<10; i++)
    {
        for(j=0; j<10; j++)
        {
            printf("%c",str[i][j]);
        }
        printf("\n");
    }
    return 0;
}

 

转载于:https://www.cnblogs.com/ccccnzb/p/4007787.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值