| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 484 人关注过本帖
标题:自己写的扫雷程序~请大家帮忙看一下有没有更好的写法?
取消只看楼主 加入收藏
阿冲
Rank: 2
等 级:论坛游民
帖 子:29
专家分:40
注 册:2009-10-5
结帖率:75%
收藏
 问题点数:0 回复次数:0 
自己写的扫雷程序~请大家帮忙看一下有没有更好的写法?
这个是老师布置的作业,随机显示雷和雷周围的数字,我是这样写的,不知道有没有更好的方法??

程序代码:
#include<iostream>
#include<ctime>
using namespace std;
int iValue(int iROW , int iCOL);
#define ROW          9    // 行数
#define COL           9    // 列数
#define BOMBNUMS  30    // 雷数
int main()
{
    char  arrInfo[ROW][COL];
    memset(arrInfo,  '0' ,  ROW * COL * sizeof(char) );    
    int iNum = 0;  // 已经布下的雷
    unsigned iBombNO = 0;
    srand( time(0) );
    int iTmpRow,  iTmpCol;   //行、列位置
    while ( iNum < BOMBNUMS )
    {
        iBombNO = rand() % (ROW * COL);
        iTmpRow = iBombNO / COL;
        iTmpCol = iBombNO % COL;
        if (arrInfo[iTmpRow][iTmpCol] == '*' )    //如果找到的位置有炸弹,重新找位置
        {
            continue;
        }            
        arrInfo[iTmpRow][iTmpCol] = '*';        // 设置为雷 
        ++iNum;   //已经布下的雷数加1
    }
    
    // 简单显示输出
    for(int j = 0; j < ROW; ++j)
    {
        for ( int k = 0; k < COL; ++k)
        {
            if (arrInfo [j][k] == '*')
            {
                cout <<" "<< '*';
            } 
            else
            {
                //开始
                int iTmp = 0;
                if ((j-1 >= 0) && (k-1 >= 0))
                {
                    if (arrInfo[j-1][k-1] == '*')
                        iTmp += 1;
                }
                
                if (j-1 >= 0)
                {
                    if (arrInfo[j-1][k] == '*')
                        iTmp += 1;
                }
                
                if ((j-1 >= 0) && (k+1 < COL))
                {
                    if (arrInfo[j-1][k+1] == '*')
                        iTmp += 1;
                }

                if (k-1 >= 0)
                {
                    if (arrInfo[j][k-1] == '*')
                        iTmp += 1;
                }

                if (k+1 < COL)
                {
                    if (arrInfo[j][k+1] == '*')
                        iTmp += 1;
                }

                if ((j+1 < ROW) && (k-1 >= 0))
                {
                    if (arrInfo[j+1][k-1] == '*')
                        iTmp += 1;
                }

                if (j+1 < ROW)
                {
                    if (arrInfo[j+1][k] == '*')
                        iTmp += 1;
                }

                if ((j+1 < ROW) && (k+1 < COL))
                {
                    if (arrInfo[j+1][k+1] == '*')
                        iTmp += 1;
                }
                //结束
                cout <<" "<< iTmp;
            }
                    
        }
        cout<<endl;    
    }
    return 0;
}

搜索更多相关主题的帖子: 扫雷 
2009-10-06 09:31
快速回复:自己写的扫雷程序~请大家帮忙看一下有没有更好的写法?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.041286 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved