码迷,mamicode.com
首页 > 其他好文 > 详细

随机步法A-Z

时间:2014-10-06 01:56:29      阅读:317      评论:0      收藏:0      [点我收藏+]

标签:style   blog   color   io   使用   ar   for   sp   div   

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

标签:style   blog   color   io   使用   ar   for   sp   div   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!