zl程序教程

您现在的位置是:首页 >  后端

当前栏目

第18周报告2:二维数组

数组 报告 18 二维
2023-09-11 14:15:57 时间
题目:定义一个8行8列的二维数组a[8][8] (1)(模板中已经完成)利用产生随机数的系统函数为其置初值(1-50之间),可能的取值如右图所示; (2)输出从左上到右下对角线上的元素的值,如对右图而言,输出为48 34 12 31 40 42 34 45;再输出从右上到左下对角线上的值; (3)将此数组视为“扫雷”游戏的界面(实际上扫雷游戏的界面一般就用二维数组保存其界面),通过键

题目:定义一个8行8列的二维数组a[8][8]

(1)(模板中已经完成)利用产生随机数的系统函数为其置初值(1-50之间),可能的取值如右图所示;

(2)输出从左上到右下对角线上的元素的值,如对右图而言,输出为48 34 12 31 40 42 34 45;再输出从右上到左下对角线上的值;

(3)将此数组视为“扫雷”游戏的界面(实际上扫雷游戏的界面一般就用二维数组保存其界面),通过键盘输入一个位置,输出其周围八个格子中的数据,如输入2 2时,输出34 30 47 2948 14 12 31(注意:一共八个,不包括该位置上的数),计算这些数的和并输出。另外,如果选择的位置在边缘或角上时,周围的格数不够八个,按实际个数输出。请用循环有规律地列举出来各个值,不要采用顺序结构逐个罗列。

(4)改变数组中的值并输出。改变的规则是:从第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 3033 63 60 64,a[2]行依次为77 68….114。


 

实验目的:学会二维数组的操作

实验内容:二维数组的操作

/* 程序头部注释开始

* 程序的版权和版本声明部分

* Copyright (c) 2011, 烟台大学计算机学院学生

* All rights reserved.

* 文件名称: array.cpp 

* 作 者: 贺利坚 

* 完成日期: 2011 年 12 月 22 日

* 版 本号: v1.0 

* 对任务及求解方法的描述部分

* 输入描述:由程序产生随机数作为初始值

* 问题描述:……

* 程序输出:……

#include iostream 

#include time.h 

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);

 out(a);

 return 0;

void setdata(int a[8][8])

 int i,j;

 srand(time(NULL));//需要用当前时间作“种子”,以便每次运行取得的序列不同

 for(i=0;i i++)

 for(j=0;j j++)

 a[i][j]=rand()%50+1; //了解rand()函数,请阅读有关系统函数的文档

 return;

void out(int a[8][8])

 int i,j;

 for(i=0;i i++)

 for(j=0;j 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 i++)

 cout a[i][i] ; //不少同学还在刻意用a[i][j]形式,很麻烦地保持i和j的关系

 cout endl;

 //输出从右上到左下对角线上的元素的值

 cout "出右上到左下对角线上的元素的值为:" endl;

 for(i=0;i i++)

 cout a[i][7-i] \t; // a[i][7-i],不正是斜对角的表示吗?

 cout endl;

 cout endl;

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 "这些数的和是:" sum endl endl;

void change(int a[8][8])

 int i,j;

 for(i=1;i i++)

 for(j=0;j j++)

 a[i][j]=a[i-1][j]+a[i-1][(j+1)%8]; //(j+1)%8将使j=7时,访问到a[i][0]元素

 return;

}


薛广晨的输出很好看,请参考:http://blog.sina.com.cn/s/blog_8ff404c40100wky3.html

 

扩展题求解参考:

//简单的马走日

void chess(int a[8][8],int x, int y)

 cout "按日字型走法,a[" x "][" y "]可达:" endl;

 go(a, x - 1, y - 2);

 go(a, x - 2, y - 1);

 go(a, x - 2, y + 1);

 go(a, x - 1, y + 2);

 go(a, x + 1, y + 2);

 go(a, x + 2, y + 1);

 go(a, x + 2, y - 1);

 go(a, x + 1, y - 2);

void go(int a[8][8],int i, int j)

 if((i = 0) (i = 7) (j = 0) (j = 7))

 cout "(" i "," j "," a[i][j] ")" endl;

}


 


生成以周统计的表头,跨月份的周算在后一个月 这是人力统计的一个表格的表头,根据月份,划分周,每周从周一开始到周日(国内习惯性)。而跨月份的周算在前一个月还是后一个月,我们的需求是算在后一个月。根据情况而定。
2014秋C++ 第14周项目 二维数组 课程主页在http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在云学堂“贺老师课堂”同步展示,使用的帐号请到课程主页中查看。  【项目1-折腾二维数组】创建一个5行4列的二维整型数组,通过初始化,为数组中的前两列的10个元素赋初值,然后: 通过键盘输入,使后两列的10个元素获得值; 按行序优先输出数组元素; 将所有元素值乘
2014秋C++ 第13周项目 C++中的一维数组 课程主页在http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在云学堂“贺老师课堂”同步展示,使用的帐号请到课程主页中查看。  【项目1 - 数组大折腾】(1)创建一个有20个元素的整型数组,通过初始化,为数组中的前10个元素赋初值,然后通过键盘输入后10个元素的值,从前往后(从第0个到第19个)输出数组中元素的值,每5个
C++第14周项目5——字符串统计 课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759 【项目5-字符串统计】阅读下面的程序,完成类似的功能 #include iostream #include cstdio using namespace std; int main() char str[50];
编函数,完成冒泡排序。要求不能改变下面的main函数。 重点体会:(1)排序算法;(2)数组名作形式参数,将能改变作为实际参数的数组的值,实际参数传递给形式参数的是数组的地址值,也是传值;(3)形式参数中不指定数组大小,实际数组
C++第9周项目5 - -二维数组类Douary 课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565,本周题目链接:http://blog.csdn.net/sxhelijian/article/details/8841620 【项目5(选做)-二维数组类Douary】建立一个二维数组类Douary,使该类中有以下数据成员、成员函数及友员函数,完成矩阵的输入、输出、加
C++第17周项目6——指针版多科成绩计算 课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565 【项目6(选做)- 指针版多科成绩计算】(接15周项目4)用二维数组score[][4]保存同学们的高数、英语、C++成绩及总成绩。在此基础上,尽量用指针法访问数组,完成下面的操作:(1)设计输入成绩的函数,输入3科成绩后可以自动求出总分,并将数据全保存到数组中;(2)
C++第15周项目6——存储棋盘 课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565 【项目6-体会棋盘游戏中的数据存储】 定义一个8行8列的二维数组a[8][8]。 (1)为二维数组中的数据赋50以内的随机数(程序模板中setdata()函数已经完成,利用产生随机数的系统函数实现),可能的取值如上图所示; (2)设计函数out()按行输出二
C++第13周项目1——Fibnacci序列 课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565 【项目1-Fibnacci序列】输出Fibnacci序列的第20个数。要求提交两个程序,fib(int n)的实现分别用迭代方法与递归方法实现。提示:如实现困难,先从讲义看求阶乘的迭代方法与递归方法实现,深入体会后再进行设计。参考解答: //迭代法 #include
贺利坚 烟台大学计算机学院教师,建设系列学习资源,改革教学方法,为IT菜鸟建跑道,让大一的孩子会编程,为迷茫的大学生出主意,一起追求快乐的大学。 著书《逆袭大学:传给IT学子的正能量》,帮助处于迷茫中的大学