加载中…
个人资料
薛广晨
薛广晨
  • 博客等级:
  • 博客积分:0
  • 博客访问:11,751
  • 关注人气:8
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
相关博文
推荐博文
谁看过这篇博文
加载中…
正文 字体大小:

第18周报告2:二维数组

(2011-12-22 14:38:37)
标签:

杂谈

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

* 程序头部注释开始
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:学会二维数组的操作                            
* 作    者:薛广晨                         
* 完成日期:2011 年 12 月 22 日
* 版 本 号:x1.0        

* 对任务及求解方法的描述部分
* 输入描述:由程序产生随机数作为初始值
* 问题描述:……
* 程序输出:……
* 程序头部的注释结束
#include  <iostream>
#include"iomanip"
#include <time.h>
using namespace std;
void setdata(int a[8][8]);  //设置随机数
void out(int a[8][8],int num);  //输出数组
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,0); 
 outDiagonal(a);
    cout<<"输入一个位置:";
 cin>>x>>y;
 mine(a,x,y);
 change(a);
 out(a,1);
 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 num)
{
 int i, j;
 if(num=0)
 {
  cout<<"┌─┬─┬─┬─┬─┬─┬─┬─┐"<<endl;
     for(i=0; i<8; i++)
  {
   for(j=0; j<8; j++)
   {
    cout<<"│"<<setiosflags(ios::left)<<setw(2)<<a[i][j];

                cout<<"│";

   }
      cout<<endl;
            if(i==7)
    cout<<"└─┴─┴─┴─┴─┴─┴─┴─┘"<<endl;
            else
                cout<<"├─┼─┼─┼─┼─┼─┼─┼─┤"<<endl;

  }
 }
 else
 {
  cout<<"┌──┬──┬──┬──┬──┬──┬──┬──┐"<<endl;
        for(i=0;i<8;i++)
  {
   for(j=0;j<8;j++)
            cout<<"│"<<setiosflags(ios::left)<<setw(4)<<a[i][j];
            cout<<"│";
            cout<<endl;
            if(i==7)
    cout<<"└──┴──┴──┴──┴──┴──┴──┴──┘"<<endl;
            else
            cout<<"├──┼──┼──┼──┼──┼──┼──┼──┤"<<endl;
  }
 }
}

 


void outDiagonal(int a[8][8])
{
 int i;
 cout<<"输出从左上到右下对角线上的元素的值:"<<endl;
 for( i=0; i<8; i++)
 {
  cout<<setw(4)<<a[i][i];
 }
    cout<<endl;

    cout<<"输出从右上到左下对角线上的元素的值:"<<endl;
    for( i=0;i<8;i++)
 {
  cout<<setw(4)<<a[i][7-i];
 }
        cout<<endl;

}

void mine(int a[8][8],int x, int y)
{
 int add=0;
    for(int i=-1;i<=1;i++)
  for(int 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<<setw(4)<<a[x+i][y+j];
                       add+=a[x+i][y+j];
       }
  }

        cout<<endl;
        cout<<"它们的和为:"<<add<<"。"<<endl;
}

void change(int a[8][8])
{
 for(int i=1;i<8;i++)
  for(int j=0;j<8;j++)
   a[i][j]=a[i-1][j]+a[i-1][(j+1)%8]; 
}
运行结果:(贴图)第18周报告2:二维数组

经验积累:好好的敲,以免出错,认真一些就可以避免很多错误。


上机感言:借用了一下王兴峰的mine函数,太高明啦,佩服啊。

0

阅读 评论 收藏 转载 喜欢 打印举报/Report
  • 评论加载中,请稍候...
发评论

    发评论

    以上网友发言只代表其个人观点,不代表新浪网的观点或立场。

      

    新浪BLOG意见反馈留言板 电话:4000520066 提示音后按1键(按当地市话标准计费) 欢迎批评指正

    新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 会员注册 | 产品答疑

    新浪公司 版权所有