么么哒思密哒


私信TA

用户名:firstofall

访问量:1088

签 名:

等  级
排  名 26033
经  验 537
参赛次数 0
文章发表 1
年  龄 0
在职情况 学生
学  校 崂山技工学院
专  业

  自我简介:

解题思路:从上下左右开始编代码

注意事项:两个判断循环条件不等于-1以及横纵坐标的范围限制需要特别注意

参考代码:

#include<iostream>

#include<math.h>

#include<string.h>

#include<stdlib.h>

using namespace std;

int main()

{

    int a[202][202],b,m,n,i,j,k;

    cin>>m>>n;

    for(i=0; i<m; i++) //输入数字矩阵

        for(j=0; j<n; j++)

        {

            cin>>a[i][j];

        }


    int sum=0,x=0,y=0;//矩阵的起始条件和位置


    while(sum<m*n) //判断取到的数字总数,以期是否结束循环

    {

        //down

        while(x<m&&a[x][y]!=-1)

        {

            cout<<a[x][y]<<" ";

            a[x][y]=-1;

            sum++;

            x++;

        }

        //跳出时,x==m,x从0开始,所以需要-1

        x--;

        y++;

//right

        while(y<n&&a[x][y]!=-1)

        {

            cout<<a[x][y]<<" ";

            a[x][y]=-1;

            sum++;

            y++;

        }

        y--;

        x--;

        //up

        while(x>=0&&a[x][y]!=-1)

        {

            cout<<a[x][y]<<" ";

            a[x][y]=-1;

            sum++;

            x--;

        }

        x++;

        y--;

        //left

        while(y>=0&&a[x][y]!=-1)

            //a[x][y]的不等于-1的条件使得x=1s时停了下来

        {

            cout<<a[x][y]<<" ";

            a[x][y]=-1;

            sum++;

            y--;

        }

        y++;

        x++;

    }

    return 0;

}


 

0.0分

0 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区