【CCF】Z字形扫描

这题的关键是将整个扫描的过程,拆分成很多次斜着操作数组的过程。

而且这个过程中可以建立如下规律:

(1)一斜线上的元素个数与切换到下一条斜线这一操作之间建立规律。

先讨论左上部分的数组:

1)当元素个数为偶数时,要输出的数组元素从上一条斜边的末端变换到下一条斜边的始端,y(即纵坐标)保持不变,++x(即横坐标);

2)元素个数为奇数,切换元素时,x(即横坐标)不变,++y(即纵坐标);

再讨论右下部分的数组:

1)当元素个数为偶数时,要输出的数组元素从上一条斜边的末端变换到下一条斜边的始端,x(即横坐标)保持不变,++y(即纵坐标);

2)元素个数为奇数,切换元素时,y(即纵坐标)不变,++x(即横坐标);

(2)斜线上元素个数从1到n,再从n到1

(3)斜线上元素个数为偶数时,输出元素的方向应向左下角移动,位移量为dx = 1,dy = -1

为奇数时,输出元素的方向应向右上角移动,位移量为dx = -1,dy = 1;

总结之下可以写为

cpp 复制代码
int dx[2] = {1,-1};
int dy[2] = {-1,1};

当times(即当前斜线上元素的个数)%2 == 0时,说明为偶数,此时dx = 1,dy = -1,符合上面的规律。

cpp 复制代码
#include<iostream>
using namespace std;

int dx[2] = {1,-1};
int dy[2] = {-1,1};


int main()
{
	int n;
	cin>>n;
	int a[n][n] = {0};
	for(int i=0;i<n;++i)
	{
		for(int j=0;j<n;++j)
		{
			cin>>a[i][j];
		}
	}
	
	//times变量记录当前是第几个斜线,
	//同时记录当前斜线上有几个元素,
	//奇数向上,偶数向下 
	int times = 1;
    //x,y记录当前遍历到数组哪个位置的元素
    //规定向右为x正向,向下为y正向
	int x = 0;
	int y = 0;

	
	for(int i=0;i<2*n-1;++i)
	{
		for(int j=0;j<times;++j)
		{
			if(j == 0)
			cout<<a[x][y]<<' ';
			else
			cout<<a[x+=dx[times%2]][y+=dy[times%2]]<<' ';
		}
        //下面实现切换斜线的功能
		if(i < n-1)//数组左上部分和右下部分切换斜线的操作不同 
		{
			if(times%2 == 1)//奇数
				++y;
			else
				++x;
			++times;
		}
		else // 数组右下部分
		{
			if(times%2 == 0)
			++y;
			else
			++x;
			--times;
		}
	}
	
	return 0;
}
相关推荐
C雨后彩虹5 分钟前
斗地主之顺子
java·数据结构·算法·华为·面试
CC.GG13 分钟前
【C++】AVL树
java·开发语言·c++
鸽鸽程序猿18 分钟前
【刷题册】二
算法
CoderCodingNo28 分钟前
【GESP】C++四级真题 luogu-B4416 [GESP202509 四级] 最长连续段
开发语言·c++·算法
xjxijd28 分钟前
工业元宇宙 IDC 支撑:数字孪生算法 + 边缘服务器,生产调度响应速度提 3 倍
运维·服务器·算法
程序员zgh39 分钟前
代码重构 —— 读后感
运维·c语言·开发语言·c++·重构
xwz小王子44 分钟前
UniBYD:超越人类示教模仿的跨实体机器人操作学习统一框架
学习·算法·机器人·跨实体
liulilittle1 小时前
moodycamel::ConcurrentQueue 清空队列的方法论
开发语言·c++
跨境卫士苏苏1 小时前
突围新品广告泥潭:亚马逊广告底层逻辑大重构
大数据·人工智能·算法·重构·亚马逊·防关联
旧梦吟1 小时前
脚本网页 三人四字棋
前端·数据库·算法·css3·html5