C++第15周项目6——存储棋盘

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565

【项目6-体会棋盘游戏中的数据存储】
  定义一个8行8列的二维数组a[8][8]。
  

  (1)为二维数组中的数据赋50以内的随机数(程序模板中setdata()函数已经完成,利用产生随机数的系统函数实现),可能的取值如上图所示;
  (2)设计函数out()按行输出二维数组中的数据;
  (3)设计函数outDiagonal()输出从左上到右下对角线上的元素的值,如对图的数据而言,输出为48 34 12 31 40 42 34 45;再输出从右上到左下对角线上的值;
  (4)将此数组视为“扫雷”游戏的界面(实际上扫雷游戏的界面一般就用二维数组保存其界面),通过键盘输入一个位置,输出其周围八个格子中的数据,如输入2 2时,输出34 30 47 29 48 14 12 31(注意:一共八个,不包括该位置上的数)(参见图中的黄色部分),计算这些数的和并输出。另外,如果选择的位置在边缘或角上时,周围的格数不够八个,按实际个数输出。请用循环有规律地列举出来各个值,不要采用顺序结构逐个罗列。这项功能由函数mine()完成。
  (5)设计函数change()改变数组中的值。改变的规则是:从第2行(即a[1]行)开始到最后一行,每一元素是其正上方元素和右上方元素之和,例如a[1][0]取a[0][0]和a[0][1]之和,a[1][1]取a[0][1]和a[0][2]之和,……。对各行最后一列元素,其右上方无数据,取上一行中的第一个元素,如a[1][7]取a[0][7]和a[0][0]之和。对上图中的数据,a[1]行的  元素将依次为:50 27 41 30 33 63 60 64,a[2]行依次为77 68…114。

参考解答:

#include  <iostream>
#include <ctime>
#include <cstdlib>
using namespace std;
void setdata(int a[8][8]);  //设置随机数
void out(int a[8][8]);             //输出数组
void outDiagonal(int a[8][8]); //输出对角线元素的值
void mine(int a[8][8],int x, int y);                  //按“扫雷”游戏的规则输出相邻格子
void change(int a[8][8]);                                //按要求改变数值
int main()
{
    int a[8][8],x,y;
    setdata(a);
    out(a);
    outDiagonal(a);
    cout<<"输入一个位置:";
    cin>>x>>y;
    mine(a,x,y);
    change(a);
    cout<<"按规则改变后的数组值为:"<<endl;
    out(a);
    return 0;
}

void setdata(int a[8][8])
{
    int i,j;
    srand(time(NULL));//需要用当前时间作“种子”,以便每次运行取得的序列不同
    for(i=0; i<8; i++)
        for(j=0; j<8; j++)
            a[i][j]=rand()%50+1;  //了解rand()函数,请阅读有关系统函数的文档
    return;
}

//按行序优先输出数组
void out(int a[8][8])
{
    int i,j;
        cout<<"按行序输出的二维数组为:"<<endl;
    for(i=0; i<8; i++)
    {
        for(j=0; j<8; j++)
            cout<<a[i][j]<<'\t';
        cout<<endl;
    }
    cout<<endl;
    return;
}

//输出对角线元素的值(从左上到右下、从右上到左下)
void outDiagonal(int a[8][8])
{
    int i;
    //输出从左上到右下对角线上的元素的值
    cout<<"从左上到右下对角线上的元素的值为:"<<endl;
    for(i=0; i<8; i++)
        cout<<a[i][i]<<'\t';   //不必刻意用a[i][j]形式,很麻烦地保持i和j的关系
    cout<<endl;
    //输出从右上到左下对角线上的元素的值
    cout<<"从右上到左下对角线上的元素的值为:"<<endl;
    for(i=0; i<8; i++)
        cout<<a[i][7-i]<<'\t';   // a[i][7-i],斜对角
    cout<<endl;
    cout<<endl;
}

//按扫雷游戏规则,输出a[x][y]周围的8个数字
void mine(int a[8][8],int x, int y)
{
    int i,j,sum=0;
    cout<<"a["<<x<<"]["<<y<<"]周围的数是:"<<endl;
    for (i = x - 1; i <= x +1; i++)
    {
        for (j = y - 1; j<= y + 1; j++)
        {
            if ((i>= 0) && (i <= 7) && (j >= 0) && (j <= 7)&& !((i == x ) && (j == y))) //用if中的条件将不可以输出的所有元素“屏蔽”掉,要学会这种简洁的思路,不要一来就一一列举,需要写出很多if语句来完成
            {
                cout<<a[i][j]<<'\t';
                sum+=a[i][j];
            }
        }
    }
    cout<<endl<<"这些数的和是:"<<sum<<endl<<endl;
}

//按题目中所言规则更改元素的值
void change(int a[8][8])
{
    int i,j;
    for(i=1; i<8; i++)
        for(j=0; j<8; j++)
            a[i][j]=a[i-1][j]+a[i-1][(j+1)%8];  //(j+1)%8将使j=7时,访问到a[i][0]元素
    return;
}
时间: 2025-01-01 08:24:35

C++第15周项目6——存储棋盘的相关文章

2013级C++第15周项目——二维数组

课程主页在:http://blog.csdn.net/sxhelijian/article/details/11890759 [项目1-折腾二维数组]创建一个长度为5行4列的二维整型数组,通过初始化,为数组中的前两列的10个元素赋初值,然后通过键盘输入,使后两列的10个元素获得值,将所有元素值乘以3后保存在数组中.输出数组时,按行序优先输出,再按列序优先输出(输出的第一行是数组中的第一列--,其实输出的就是"转置"),再将数组"倒"着输出(即最后一行最后一列的最先输

2013-C++第15周项目参考解答链接集

课程主页在:http://blog.csdn.net/sxhelijian/article/details/11890759 [项目1-折腾二维数组]创建一个长度为5行4列的二维整型数组,通过初始化,为数组中的前两列的10个元素赋初值,然后通过键盘输入,使后两列的10个元素获得值,将所有元素值乘以3后保存在数组中.输出数组时,按行序优先输出,再按列序优先输出(输出的第一行是数组中的第一列--,其实输出的就是"转置"),再将数组"倒"着输出(即最后一行最后一列的最先输

C++第15周项目3——带姓名的成绩单

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565 [项目3-带姓名的成绩单]设score数组中存储同学们的C++成绩,增加一个数组string name[20]并赋初值,表示同学们的姓名.这两个数组中,同学的姓名与成绩的下标保持一致(例如name[1]和score[1]表示同一位同学的姓名和C++成绩).请(1)输出按成绩排序后的同学的名单:(2)输出按同学姓名排序后的成绩单(排序对象是字符串).提示:排序中交换scor

2014秋C++ 第15周项目 指针基础

课程主页在http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在云学堂"贺老师课堂"同步展示,使用的帐号请到课程主页中查看.  [项目1-打入"内部"寻"内幕"]下面是一段使用了指针的程序.请利用"单步"执行的方式运行程序,深刻理解"指针变量存储的是地址值"."通过指针变量间接访问"等概念.将在执行过程中留下深刻映像的

C++第15周项目3 -约瑟夫环

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565,本周题目链接:http://blog.csdn.net/sxhelijian/article/details/9018813 [项目3]Josephus(约瑟夫环)问题 n个小孩子围成一圈,从第一个小孩子开始顺时针方向数数字,到第m个小孩子离开,这样反反复复,最终只剩下一个小孩子,求第几个小孩子留下? 提示:约瑟夫环即是一个首尾相连的链表,在建立好这个环以后,从头结点开始

C++第15周项目1 -数组类

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565,本周题目链接:http://blog.csdn.net/sxhelijian/article/details/9018813 [项目1]建立专门的数组类处理有关数组的操作 数组是几乎所支持的组织数据的方法.C和C++对数组类型提供了内置支持,使我们利用数组实现软件中需要的各种实用的功能.但是,这种支持仅限于用来读写单个元素的机制.C++不支持数组的抽象abstractio

C++第15周项目1扩展1 -数组类

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565,本周题目链接:http://blog.csdn.net/sxhelijian/article/details/9018813 [项目1-扩展1]建立专门的数组类处理有关数组的操作项目1情况见:http://blog.csdn.net/sxhelijian/article/details/9052881 要求:在MyArray基础上增加下面的成员或友元函数,扩充MyArra

2014秋C++ 第15周项目2程序阅读(加注释)

课程主页在http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在云学堂"贺老师课堂"同步展示,使用的帐号请到课程主页中查看.  [项目2-阅读程序] 阅读下面的程序,先写出其运行结果,再运行对比. 支招1:按课堂上老师讲课的方式,将变量对应内存的"框子"画出来,用大脑当CPU,写出变量的变化过程: 支招2:单步执行程序,在监视(watch)窗口中观察变量的动态变化,从而掌握程序的运行机理. (1)

C++第15周项目5——-电子词典

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565 [项目5-电子词典]:做一个简单的电子词典.在文件dictionary.txt中(点此链接下载)作为调试,保存的是英汉对照的一个词典,词汇量近8000个,英文与释义间用'\t'隔开.编程序,将文件中的内容读到两个数组e[]和c[]中,分别代表英文和中文,由用户输入英文词,显示中文意思.运行程序后,支持用户连续地查词典,直到输入"0000"结束,如下图: