服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C/C++实现蛇形矩阵的示例代码

C/C++实现蛇形矩阵的示例代码

2022-08-11 10:04沈⑦今天有敲代码嘛 C/C++

本文主要介绍了C/C++实现蛇形矩阵的示例代码,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

菜鸡蒟蒻想在博客中记录一些算法学习的心得体会,会持续更新C/C++方面的题解,方便理清思路和日后复习。如果还能结识一起敲代码的小伙伴的话就更好啦嘿嘿,因为实在是太弱了,肯定免不了错误百出。欢迎批评指正,期待共同成长!

题目描述

给出一个不大于 9 的正整数 n,输出 n×n 的蛇形方阵。

从左上角填上 1 开始,顺时针方向依次填入数字,如同样例所示。注意每个数字有都会占用 3 个字符,前面使用空格补齐。

输入样例

输入

4

输出

  1  2  3  4
 12 13 14  5
 11 16 15  6
 10  9  8  7

题解部分

涉及算法模拟
各位读者有听说过“建模”一词吗?所谓“建模”,就是把事物进行抽象,根据实际问题来建立对应的数学模型。“抽象”并不意味着晦涩难懂;相反,它提供了大量的便利。计算机很难直接去解决实际问题,但是如果把实际问题建模成数学问题,就会大大地方便计算机来“理解”和“解决”。

思路

1.首先我们可以把题目抽象成数学问题,题目可以理解成为在一个方格里按一定规律填自然数,规律如下图。

C/C++实现蛇形矩阵的示例代码

(画的丑各位轻喷)
可以看出"小蛇"的走向是右、下、左、上、反复循环。

2.建模完毕之后,我们可以把这个矩阵用二维数组来表示,每填一个数就相当于x或者y变化。
注意这个坐标系的建立是根据二维数组的特性建立的x代表行、y代表列。

?
1
2
3
4
int map[15][15];
//虽然题目要求数据最大是9*9,但为了避免内存会爆一般会把数组空间开大一点。
for(i=1;i<=n*n;i++)
map[x][y]=i;

3.那如何控制方向呢?其实只需要再定义一个二维数组就可以啦。

?
1
2
3
4
5
int pos[4][2]={
        {0,1), //向右填数
        {1,0},//向下填数
        {0,-1},//向左填数
        {-1,0}};//向上填数

注意顺序一定要按小蛇的走向规律填写。
为了方便大家理解,可以来看下面这张图,正好与上面的源码对应。

C/C++实现蛇形矩阵的示例代码

通过这个方向数组,我们就很容易获得下一步的坐标。这里可以用tx,ty来表示。

?
1
2
3
int tx=x+t[d][0];
int ty=y+t[d][1];
///通过改变d来改变方向。

4.如何判断下一步要不要换方向呢?这时,tx,ty就派上用场了。
我们需要判断tx、ty是否超出边界,来决定是否转向。

?
1
2
3
4
5
6
7
8
for(i=1;i<=n*n;i++)
{
map[x][y]=i;
tx=x+pos[d][0],ty=y+pos[d][1];
if(tx>n||ty>n||tx<1||ty<1||map[tx][ty]>0)
    d=(d+1)%4;//因为只有四个方向所以d++时需要%4,使得d只能是0,1,2,3。
    x=x+pos[d][0],y=y+pos[d][1];//判断完毕后就可以知道下一步填哪啦。
}

矩阵的大小为n*n,故边界为[1,n]。
所以一旦tx,ty,超出边界,就需转向。
需要注意的是遇到之前已经填过数字的方格也需要转向。

ok核心部分已经讲解完毕,下面奉上完整代码。

完整代码

C语言版

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
#include<stdio.h>
int map[15][15];//需要定义在全局变量,好处是初始化默认值都是0。
int pos[4][2]={0,1,1,0,0,-1,-1,0};
int main()
{
    int n;
    int i,j;
    scanf("%d",&n);
    int x=1,y=1,d=0;
    for(i=1;i<=n*n;i++)
    {
        map[x][y]=i;
        int tx=x+pos[d][0],ty=y+pos[d][1];
        if(tx>n||ty>n||tx<1||ty<1||map[tx][ty]>0)
        d=(d+1)%4;
        x=x+pos[d][0],y=y+pos[d][1];
    }
    for(i=1;i<=n;i++)
    {
    for(j=1;j<=n;j++)
    printf("%3d",map[i][j]);
    printf("\n");
    }
    return 0;
}

C++版

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
#include<bits/stdc++.h>
using namespace std;
int map2[15][15];//因为c++类库太多,定义名为map编译器会产生歧义,所以在后面加个2就ok了。
int pos[4][2]={0,1,1,0,0,-1,-1,0};
int main()
{
    int n;
    cin>>n;
    int i,j;
    int x=1,y=1,d=0;
    for(i=1;i<=n*n;i++)
    {
        map2[x][y]=i;
        int tx=x+pos[d][0],ty=y+pos[d][1];
        if(tx>n||ty>n||tx<1||ty<1||map2[tx][ty])
        d=(d+1)%4;
        x=x+pos[d][0],y=y+pos[d][1];
    }
    for(i=1;i<=n;i++)
    {
    for(j=1;j<=n;j++)
    printf("%3d",map2[i][j]);
    cout<<endl;
    }
    return 0;
}

最近刚接触的c++,不过单从这题来看好像也差不多(捂脸)。

到此这篇关于C/C++实现蛇形矩阵的示例代码的文章就介绍到这了,更多相关C/C++ 蛇形矩阵内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/m0_66139206/article/details/122320723

延伸 · 阅读

精彩推荐
  • C/C++使用用C++做一颗会跳动的爱心实例代码

    使用用C++做一颗会跳动的爱心实例代码

    大家好,本篇文章主要讲的是使用用C++做一颗会跳动的爱心实例代码,感兴趣的同学赶快来看一看吧,欢迎借鉴学习C++做一颗会跳动的爱心实例代码...

    Flood_H9032022-07-19
  • C/C++c语言实现多线程动画程序示例

    c语言实现多线程动画程序示例

    这篇文章主要介绍了c语言实现多线程动画程序示例,该程序是利用opengl图形库与fmod音频库写的一个简单3d动画程序,需要的朋友可以参考下...

    C语言程序设计8852021-01-18
  • C/C++C/C++使用C语言实现多态

    C/C++使用C语言实现多态

    这篇文章主要介绍了C/C++多态的实现机制理解的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下,希望能给你带来帮助...

    久病成良医6872021-12-18
  • C/C++C语言自定义类型的保姆级讲解

    C语言自定义类型的保姆级讲解

    这篇文章主要给大家介绍了关于C语言自定义类型的保姆级讲解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    teacher dsma4932021-10-27
  • C/C++关于c语言指针的两处小tip分享

    关于c语言指针的两处小tip分享

    本篇文章是对c语言中指针的两处小tip进行了详细的分析介绍,需要的朋友参考下 ...

    C语言教程网1922020-11-29
  • C/C++C++实现线程池的简单方法示例

    C++实现线程池的简单方法示例

    这篇文章主要给大家介绍了关于C++实现线程池的简单方法,文中通过示例代码介绍的非常详细,对大家学习或者使用C++具有一定的参考学习价值,需要的朋...

    十面埋伏但莫慌8522021-09-03
  • C/C++解决C语言中使用scanf连续输入两个字符类型的问题

    解决C语言中使用scanf连续输入两个字符类型的问题

    这篇文章主要介绍了解决C语言中使用scanf连续输入两个字符类型的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    0点51 胜8702021-10-11
  • C/C++实现Dijkstra算法最短路径问题详解

    实现Dijkstra算法最短路径问题详解

    这篇文章主要介绍了实现Dijkstra算法最短路径问题详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下...

    Ouyang_Lianjun6392021-12-14