第18周报告2

本文介绍了一个关于二维数组操作的实验项目,包括如何生成随机数填充数组、输出数组内容、显示对角线元素、查找特定位置周围数值以及进行特定的数据转换等核心功能。

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

* 程序头部注释开始
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称: 第18周报告2
* 作 者: 于昊
* 完成日期: 2011 年 12 月 24 日
* 版 本号: 1.2

* 对任务及求解方法的描述部分
* 输入描述:由程序产生随机数作为初始值
* 问题描述:……
* 程序输出:……
* 程序头部的注释结束
#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<<"输入一个位置:";
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)<<setiosflags(ios::left)<<a[i][j]<<" ";
}
cout<<endl<<endl;
}
}
void outDiagonal(int a[8][8])
{
cout<<"对角线上的数字为:"<<endl;
int i,j;
for (i=0;i<8;i++)
cout<<a[i][i]<<" ";
for(j=7;j>=0;j--)
cout<<a[j][j]<<" ";
cout<<endl;
}
void mine(int a[8][8],int x, int y)
{
int i,j;
cout<<"此数值周围的数值为:"<<endl;

for(j=y-1;j<y+2;j++)
cout<<a[x-1][j]<<" ";
for(j=y-1;j<y+2;j++)
cout<<a[x+1][j]<<" ";
cout<<a[x][y-1]<<" "<<a[x][y+1]<<endl;

}
void change(int a[8][8])
{
int i,k,j;
cout<<"改变数值后为:"<<endl;
for(i=1;i<8;i++)
for(j=0;j<8;j++)
a[i][j]=a[i-1][j]+a[i-1][j+1];
for(k=1;k<8;k++)


经验积累:二维数组注意a【】【】代表什么意思,第一个括号代表行 第二个括号代表列。

只要括号里有确定的下标值就能找到相应的数值。

在使用stew()。。排列时开头要加一个#include <iomanip>


上机感言:2011的最后一个作业 终于交上了


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值