第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,改编的数组和上一行没有分开,
我就在想那里出来的那一行啊?哎,排版很重要啊!!!