_数字矩阵

题目:一个3阶的数字矩阵如下:

1 2 3

8 9 4

7 6 5

现在给定数字n(1<n≤20),输出n阶数字矩阵。

思路:

放出一条好玩的贪吃蛇,按照右下左上的顺序吃蛋糕,一边吃蛋糕,一边拉数字;多吃一个蛋糕,拉出的数字多1,直到把所有的蛋糕吃完。

因为贪吃蛇出动按照右、下、左、上4个方向,因此先定义一个按右下左上方向的偏移数组。

定义了偏移数组后,就可以从左上角开始,先向右走,只要有蛋糕或未到边界就继续前进,否则选择下一个方向(右下左上顺序),一直走下去,直到拉出的数字达到最大值n2,算法停止。

因为吃了蛋糕后,这个方格就变成了一个大于零的数字,因此可以设置为0时有蛋糕,否则没有蛋糕。初始状态全部为0。

本题因为不可以超出四周边界,因此采用四周封锁。设置一个无法行进的数值,即可达到封锁目的。在第0行和第n+1行设置数字-1,第0列和第n+1列设置数字-1,标识四周无法行进。

做了封锁之后,再也不用担心小贪吃蛇跑出边界了,它只需要按照右下左上的方向,只吃有蛋糕的格子(数值为0)就可以了。

 

#include<iostream>
#include<algorithm>
using namespace std;typedef struct{int x;int y;
} Position;int m[30][30];			//存地图 
Position here, next;	//当前位置,下一位置 
Position DIR[4] ={0,1,1,0,0,-1,-1,0};//右下左上方向数组 void Init(int n)
{for(int i=1; i<=n; ++i)for(int j=1; j<=n; ++j)m[i][j] =0;			//地图初始化为0 for(int i=0; i<=n+1; ++i)m[i][0] =m[i][n+1] =-1;	//左右围墙 for(int j=0; j<=n+1; ++j)m[0][j] =m[n+1][j] =-1; //上下围墙 
}void Solve(int n)
{m[1][1] =1;					//第一个数 here.x =here.y =1;			//初始化位置 int dirIndex =0, num =1; 	//偏移下标, 总数while(num<n*n){next.x =here.x + DIR[dirIndex].x;next.y =here.y + DIR[dirIndex].y;if(m[next.x][next.y]==0){m[next.x][next.y] =++num;	//满足条件则更新地图 here =next;					//继续走 }else{dirIndex =(dirIndex+1)%4;	//碰到围墙换方向 } } 
}int main()
{int n =0;cin>> n;Init(n);Solve(n);for(int i=1; i<=n; ++i){for(int j=1; j<=n; ++j)cout<< "\t"<< m[i][j];cout<< endl;}	return 0;
}

                                                                                                       来源:《趣学数据结构》陈小玉 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/83922.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

提升团队效率!探索多款热门一站式团队协作工具

“常见的几种团队协作工具有&#xff1a;Zoho Projects、Slack、Microsoft Teams、Asana、Trello等。” 团队协作已经成为了企业、组织和个人工作的重要组成部分。为了提高工作效率和协同能力&#xff0c;各种团队协作工具应运而生。本文将介绍团队协作工具的功能以及常见的几种…

LeetCode——有效的括号

这里&#xff0c;我提供一种用栈来解决的方法&#xff1a; 思路&#xff1a;栈的结构是先进后出&#xff0c;这样我们就可以模拟栈结构了&#xff0c;如果是‘&#xff08;’、‘{’、‘[’任何一种&#xff0c;直接push进栈就可以了&#xff0c;如果是‘}’、‘&#xff09;’…

vue3将通用组件注册成全局组件

一、问题重现 我们用过vue的人都知道会有一个components文件夹用来存放我们的通用组件&#xff1a; 这里我的通用组件就有四个&#xff0c;但是有一些是使用评率比较高的&#xff0c;如果很多地方要使用我还得导入相同的组件&#xff0c;写的都是一样的代码&#xff1a; impo…

wireshark进行网络监听

一、实验目的&#xff1a; 1&#xff09;掌握使用CCProxy配置代理服务器&#xff1b; 2&#xff09;掌握使用wireshark抓取数据包&#xff1b; 3&#xff09;能够对数据包进行简单的分析。 二、预备知识&#xff1a; 包括监听模式、代理服务器、中间人攻击等知识点&#xf…

研磨设计模式day09原型模式

目录 场景 代码实现 有何问题 解决方案 代码改造 模式讲解 原型与new 原型实例与克隆出来的实例 浅度克隆和深度克隆 原型模式的优缺点 思考 何时选用&#xff1f; 相关模式 场景 代码实现 定义订单接口 package com.zsp.bike.day08原型模式;/*** 订单的接口*…

跨境出海:如何轻松应对多账号管理

在如今的跨境电商时代&#xff0c;成功经营一个线上店铺不再仅仅需要商品和服务&#xff0c;还需要精通广告投放、营销策略等多个领域。 然而&#xff0c;老练的电商从业者知道&#xff0c;如果不重视平台账号的管理方法&#xff0c;可能会导致店铺或营销账号被关联&#xff0…

Idea配置Remote Host

一、打开RemoteHost窗口 双击shift打开全局搜索 搜索Tools→Deployment→Browse Remote Host或 idea项目顶部Tools→Deployment→Browse Remote Host 二、添加服务 右侧边栏打开RemoteHost&#xff0c;点击三个点&#xff0c;起个名字&#xff0c;选择type为SFTP&#xff…

二叉树、红黑树、B树、B+树

二叉树 一棵二叉树是结点的一个有限集合&#xff0c;该集合或者为空&#xff0c;或者是由一个根节点加上两棵别称为左子树和右子树的二叉树组成。 二叉树的特点&#xff1a; 每个结点最多有两棵子树&#xff0c;即二叉树不存在度大于2的结点。二叉树的子树有左右之分&#xf…

C++11 Lambda表达式

Lambda表达式简介 Lambda表达式是现代C在C11和更高版本中的一个新的语法糖。它是一种定义匿名函数对象的便捷方法&#xff0c;常用于封装传递给算法或异步方法的几行代码。Lambda表达式可以在调用或作为函数参数传递的位置处定义&#xff0c;可以捕获上下文中的变量供函数使…

目标检测(Object Detection):Fast R-CNN,YOLO v3

目录 目标检测(Object Detection) R-CNN SPPNet Fast R-CNN YOLO v1 YOLO v2 YOLO v3 目标检测(Object Detection) 任务是计算机视觉中非常重要的基础问题&#xff0c;也是解决图像分割、目标跟踪、图像描述等问题的基础。目标检测是检测输入图像是否存在给定类别的物体…

适配器模式实现stack和queue

适配器模式实现stack和queue 什么是适配器模式&#xff1f;STL标准库中stack和queue的底层结构stack的模拟实现queue的模拟实现 什么是适配器模式&#xff1f; 适配器是一种设计模式(设计模式是一套被反复使用的、多数人知晓的、经过分类编目的、代码设计经验的总结)&#xff…

浅谈泛在电力物联网发展形态与技术挑战

安科瑞 华楠 摘 要&#xff1a;泛在电力物联网是当前智能电网发展的一个方向。首先&#xff0c;总结了泛在电力物联网的主要作用和价值体现&#xff1b;其次&#xff0c;从智能电网各个环节概述了物联网技术在电力领域的已有研究和应用基础&#xff1b;进而&#xff0c;构思并…