C++程序设计实验报告(二十七)
2012-02-02 18:14
423 查看
实验目的:学会二维数组的操作
实验内容:二维数组的操作
* 程序头部注释开始
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:renwu.cpp
* 作 者:宋本一
* 完成日期:2011 年 12 月 25 日
* 版 本号:v18.2
* 对任务及求解方法的描述部分
* 输入描述:由程序产生随机数作为初始值
* 问题描述:……
* 程序输出:……
* 程序头部的注释结束
#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<<endl<<"输入一个位置:";
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++)
{
if(j%8==0)
{
cout<<endl;
}
cout<<a[i][j]<<" ";
}
cout<<endl<<endl;
}
void outDiagonal(int a[8][8])
{
int i;
//左上右下
for(i=0;i<8;i++)
cout<<a[i][i]<<" ";
cout<<endl;
//右上左下
for(i=0;i<8;i++)
cout<<a[i][7-i]<<" ";
}
void mine(int a[8][8],int x, int y)
{
int i,j,add=0;
for(i=-1;i<=1;i++)
for(j=-1;j<=1;j++)
{
if(x!=x+i||y!=y+j)
if((x+i>=0)&&(y+j>=0))
if((x+i<=7)&&(y+j<=7))
{
cout<<a[x+i][y+j]<<" ";
add+=a[x+i][y+j];
}
}
cout<<endl;
cout<<"和为:"<<add<<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];
}
for(i=1;i<8;i++)
for(j=0;j<8;j++)
{
a[i-1][j]=a[i][j];
}
}
运行结果:
上机感言:
算法很重要!有难度...
实验内容:二维数组的操作
* 程序头部注释开始
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:renwu.cpp
* 作 者:宋本一
* 完成日期:2011 年 12 月 25 日
* 版 本号:v18.2
* 对任务及求解方法的描述部分
* 输入描述:由程序产生随机数作为初始值
* 问题描述:……
* 程序输出:……
* 程序头部的注释结束
#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<<endl<<"输入一个位置:";
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++)
{
if(j%8==0)
{
cout<<endl;
}
cout<<a[i][j]<<" ";
}
cout<<endl<<endl;
}
void outDiagonal(int a[8][8])
{
int i;
//左上右下
for(i=0;i<8;i++)
cout<<a[i][i]<<" ";
cout<<endl;
//右上左下
for(i=0;i<8;i++)
cout<<a[i][7-i]<<" ";
}
void mine(int a[8][8],int x, int y)
{
int i,j,add=0;
for(i=-1;i<=1;i++)
for(j=-1;j<=1;j++)
{
if(x!=x+i||y!=y+j)
if((x+i>=0)&&(y+j>=0))
if((x+i<=7)&&(y+j<=7))
{
cout<<a[x+i][y+j]<<" ";
add+=a[x+i][y+j];
}
}
cout<<endl;
cout<<"和为:"<<add<<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];
}
for(i=1;i<8;i++)
for(j=0;j<8;j++)
{
a[i-1][j]=a[i][j];
}
}
运行结果:
上机感言:
算法很重要!有难度...
相关文章推荐
- C++程序设计实验报告(二十七)---第二周任务一(自定义函数用递归思想,即不断调用,反向输出二进制)
- C++程序设计实验报告——三角形
- C++程序设计实验报告(四) 错在哪
- C++程序设计实验报告(十四)
- C++程序设计实验报告(四十八)---第七周任务一
- C++程序设计实验报告(十二)----计算sin和cos的近似值
- C++程序设计实验报告(二十四)
- C++程序设计实验报告(二)
- C++程序设计实验报告(三)
- C++程序设计实验报告【5.1.2】
- C++程序设计实验报告【5.1.3】
- C++程序设计实验报告(五)
- C++程序设计实验报告(十五)
- C++程序设计实验报告(四十九)---第七周任务二
- C++程序设计实验报告(十三)---用函数完成分段数学函数的求解
- C++程序设计实验报告(二十五)
- C++程序设计实验报告(八十二)---第十六周任务#3-2(学会二分查找)
- C++程序设计实验报告(二十九)---第二周任务三(3-1)
- C++程序设计实验报告(六十二)---第十周任务1
- C++程序设计实验报告(四十三)---第六周任务一