news 2026/5/23 7:09:37

Z字形扫描ccf

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Z字形扫描ccf

一、Z 字形扫描规则总结(非常关键)

对于一个 n × n 矩阵:

所有元素都位于若干条 副对角线 上

副对角线编号:

d = 行号 i + 列号 j

范围:0 ~ 2n-2

扫描顺序:

按 d = 0 → 2n-2 依次扫描

每条对角线的遍历方向固定为:

从上到下(行递增)

即 i 从小到大

⚠️ 这正好和题目给的样例完全一致

二、以样例为例(4×4)

矩阵:

1 5 3 9
3 7 5 6
9 4 6 4
7 3 1 3

按 i + j 分组:

d 元素
0 (0,0) → 1
1 (0,1),(1,0) → 5,3
2 (0,2),(1,1),(2,0) → 3,7,9
3 (0,3),(1,2),(2,1),(3,0) → 9,5,4,7
4 (1,3),(2,2),(3,1) → 6,6,3
5 (2,3),(3,2) → 4,1
6 (3,3) → 3

拼接后正是:

1 5 3 9 7 3 9 5 4 7 3 6 6 4 1 3

三、Java 实现(推荐,O(n²),n≤500 完全没问题)

importjava.util.*;publicclassMain{publicstaticvoidmain(String[]args){Scannersc=newScanner(System.in);intn=sc.nextInt();int[][]a=newint[n][n];for(inti=0;i<n;i++){for(intj=0;j<n;j++){a[i][j]=sc.nextInt();}}StringBuildersb=newStringBuilder();// d = i + jfor(intd=0;d<=2*n-2;d++){for(inti=0;i<n;i++){intj=d-i;if(j>=0&&j<n){sb.append(a[i][j]).append(" ");}}}// 去掉末尾空格System.out.println(sb.toString().trim());}}

一、为什么你会得到这个“错误输出”?

你得到的是:

1 5 3 3 7 9 9 5 4 7 6 6 3 4 1 3

而正确答案是:

1 5 3 9 7 3 9 5 4 7 3 6 6 4 1 3

根本原因只有一句话:

题目中的“Z 字形扫描”不是“每条对角线都同方向”
而是“对角线方向交替变化”

我之前给你的代码是:

for (d = 0 … 2n-2)
for (i 从小到大)
输出 a[i][d-i]

👉 这叫 单向对角线扫描
👉 不是题目要求的 Zigzag

二、真正的 Zigzag 规则(以题目为准)

仍然按:

d = i + j

分组,但 遍历方向取决于 d 的奇偶性:

规则总结
d 的奇偶 遍历方向
d 为偶数 从下往上(i 大 → i 小)
d 为奇数 从上往下(i 小 → i 大)

这才是 Z 字形 的来源(方向来回折返)

三、用样例严格验证一遍(关键)
d = 2(偶数)

对角线元素:

(0,2)=3
(1,1)=7
(2,0)=9

偶数 ⇒ 反向输出:

9 7 3

✔️ 正确答案中正是这个顺序

d = 3(奇数)
(0,3)=9
(1,2)=5
(2,1)=4
(3,0)=7

奇数 ⇒ 正向输出:

9 5 4 7

✔️ 完全一致

四、修正后的正确 Java 代码 ✅

importjava.util.*;publicclassMain{publicstaticvoidmain(String[]args){Scannersc=newScanner(System.in);intn=sc.nextInt();int[][]a=newint[n][n];for(inti=0;i<n;i++){for(intj=0;j<n;j++){a[i][j]=sc.nextInt();}}StringBuildersb=newStringBuilder();for(intd=0;d<=2*n-2;d++){if(d%2==0){// 偶数:从下往上for(inti=n-1;i>=0;i--){intj=d-i;if(j>=0&&j<n){sb.append(a[i][j]).append(" ");}}}else{// 奇数:从上往下for(inti=0;i<n;i++){intj=d-i;if(j>=0&&j<n){sb.append(a[i][j]).append(" ");}}}}System.out.println(sb.toString().trim());}}

五、为什么这种才叫“Z 字形”?

如果你把方向画出来:

↘ ↗ ↘ ↗ ↘

就会发现路径在 对角线上不断来回折返,视觉上是一个连续的 Z / 反 Z / Z / 反 Z

👉 这和 JPEG 的 Zigzag 扫描是同一个思想

六、总结一句(非常适合考试 / 面试)

Zigzag 扫描 =
按 i+j 分对角线 + 按对角线编号奇偶交替方向

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/22 12:22:06

10、系统安全配置强化指南

系统安全配置强化指南 1. 概述 入侵者常采用多种技术来隐藏自己的踪迹并确保对受害主机的持续root访问,从清理日志文件到安装后门和rootkit等。检测高级黑客的存在往往十分困难,因此,强化主机的策略和配置至关重要。以下将详细介绍如何对系统的默认设置和常用服务进行加固…

作者头像 李华
网站建设 2026/5/22 7:51:39

14、夏普 Zaurus PDA 黑客工具介绍

夏普 Zaurus PDA 黑客工具介绍 在网络安全和渗透测试领域,有许多工具可以用于不同的目的,如端口扫描、建立安全隧道、测试防火墙规则等。本文将介绍一些可用于夏普 Zaurus PDA 的工具及其功能、下载地址和使用方法。 1. BING Bing 是一个简单的脚本,可自动执行端口扫描。…

作者头像 李华
网站建设 2026/5/21 20:22:25

15、Zaurus PDA安全工具与相关技术解析

Zaurus PDA安全工具与相关技术解析 1. Perl与Zaurus PDA 许多安全工具,如Nikto和Whisker Web漏洞扫描器,都是用Perl语言编写的。由于Perl是一种解释型语言,因此无需重新编译现有的Perl脚本,就可以在Zaurus上运行它们。你可以在http://zaurus.frontgarden.net/perl.html获…

作者头像 李华
网站建设 2026/5/22 10:31:20

晨控CK-GW04S-EIP与基恩士KV-X520系列PLC配置EtherNetIP通讯连接手册

晨控CK-GW04S-EIP与基恩士KV-X520系列PLC配置EtherNetIP通讯连接手册CK-GW04S系列是晨控为工业多通道需求研制的一款网关控制器,方便用户集成到PLC等控制系统中&#xff0c;系统集成了4路读写接口&#xff0c;并且支持大部分工业协议ModbusTCP、Profinet、EtherNet/lP、EtherCa…

作者头像 李华
网站建设 2026/5/22 12:47:36

21、Iptables与Snort规则模拟及Fwsnort部署

Iptables与Snort规则模拟及Fwsnort部署 1. Iptables状态匹配与规则应用 Iptables的状态匹配扩展提供了强大的数据包过滤功能。通过 iptables -m state -h 命令可以查看状态匹配的选项,其版本为v1.3.7,支持的状态选项包括 INVALID 、 ESTABLISHED 、 NEW 、 RELATE…

作者头像 李华
网站建设 2026/5/19 20:14:16

29、实用的 awk 程序集合

实用的 awk 程序集合 在文本处理和自动化任务中,awk 是一个强大且灵活的工具。下面将介绍多个实用的 awk 程序,涵盖文件分割、输出复制、去重、计数等多个方面。 1. for 循环测试 在 PROCINFO 数组中,任何补充组的索引为 “group1” 到 “groupN”(N 为补充组的总数),…

作者头像 李华