第18周报告2 二维数组

本文详细介绍了二维数组的基本操作,并通过实例展示了如何利用二维数组实现扫雷游戏的规则和逻辑,包括设置随机数、输出数组、显示对角线元素、按照游戏规则输出相邻格子的数字以及改变数组值等操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

第18周报告2:二维数组
实验目的:学会二维数组的操作
实验内容:二维数组的操作

/*
 * 程序的版权和版本声明部分
 * Copyright (c) 2011, 烟台大学计算机学院学生
 * Copyright (c) 2011, 烟台大学计算机学院学生
 * All rights reserved.
 * 文件名称: 二维数组
 * 作 者: 姜雅明
 * 完成日期: 2011 年 12 月 23 日
 * 版 本号: 1.0

 * 对任务及求解方法的描述部分
 * 输入描述:由程序产生随机数作为初始值
 * 问题描述:……
 * 程序输出:……
 * /

#include <iostream>
#include <time.h>
#include <iomanip>

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<<"\n输入一个位置:";
	
	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<8;i++)
	{
		for(j=0;j<8;j++)
		{
			a[i][j]=rand()P+1;
		}
	}
	return;
}

void out(int a[8][8])
{
	int i, j;
	
	for(i = 0; i < 8; i++)
	{
		for(j = 0; j < 8; j++)
		{ 
			cout << setw(5) << a[i][j] ;
		}
		cout << endl;
	}
	cout << endl;
	return;
}

void outDiagonal(int a[8][8])
{
	int i, j;
	
	cout << "左上到右下:";
	
	for(i = 0; i < 8; i++)
	{
		for(j = 0; j < 8; j++)
		{
			if(i == j)
				
				cout << setw(5) << a[i][j];
		}
	}
	cout << endl;
	
	cout << "\n右上到左下:";
	
	j = 7;
	
	for(i = 0; i < 8; i++)
	{
		cout << setw(5) << a[i][j];
		
		j--;
	}
	cout << endl;
	
	return;
}

void mine(int a[8][8],int x, int y)
{
	int i, j, sum = 0;
	
	cout << "\n周围的数有:";
	
	for(i = x - 1; i <= x + 1; i++)
	{
		for(j = y - 1; j <= y +1; j++)
		{
			if(i < 0 || j < 0)
			{
				continue;
			}
			if(i > 7 || j > 7)
			{
				continue;
			}
			if(i != x || j != y) //除去中间的那个数
			{
				cout << setw(5) << a[i][j];
				
				sum = sum + a[i][j];
			} 
		}
	}
	cout << "\n\n和为:" << setw(5) << sum << endl;
	return;
}

void change(int a[8][8])
{
	int i, j;
	
	cout << "\n改编后的数组为:\n";
	
	for(i = 1; i < 8; i++)
	{
		for(j = 0; j < 7; j++)
		{
			a[i][j] = a[i - 1][j] + a[i - 1][j + 1];
		}
		a[i][7] = a[i - 1][7] + a[i - 1][0];
	}
	return;
}


 

运行结果:



经验积累:

1. 多想下,有时候要多拐个弯才能到


上机感言:

开始因为去不掉中间的那个数而发狂···写的是&& ,后来想通了。

然后又出现了改编后的数组的问题,我在输入的时候习惯输入了1 1,改编的数组和上一行没有分开,

我就在想那里出来的那一行啊?哎,排版很重要啊!!!


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值