首页 > 其他 > 详细

随机步法A-Z

时间:2014-10-06 00:38:39      阅读:299      评论:0      收藏:0      [点我收藏+]

程序是生成一个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;
}

 

随机步法A-Z

原文:http://www.cnblogs.com/ccccnzb/p/4007787.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!