CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址

CCF CSP 201412-2 Z字形扫描

问题描述

  在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag Scan)。给定一个n×n的矩阵,Z字形扫描的过程如下图所示:

  对于下面的4×4的矩阵,
  1 5 3 9
  3 7 5 6
  9 4 6 4
  7 3 1 3
  对其进行Z字形扫描后得到长度为16的序列:
  1 5 3 9 7 3 9 5 4 7 3 6 6 4 1 3
  请实现一个Z字形扫描的程序,给定一个n×n的矩阵,输出对这个矩阵进行Z字形扫描的结果。

输入格式

  输入的第一行包含一个整数n,表示矩阵的大小。
  输入的第二行到第n+1行每行包含n个正整数,由空格分隔,表示给定的矩阵。

输出格式

  输出一行,包含n×n个整数,由空格分隔,表示输入的矩阵经过Z字形扫描后的结果。

样例输入

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

样例输出

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

评测用例规模与约定

  1≤n≤500,矩阵元素为不超过1000的正整数。
 
解析
 
 

代码

C++

解法一

  1. #include <iostream>
  2.  
  3. using namespace std;
  4.  
  5. int n;
  6. int a[][];
  7.  
  8. int main() {
  9. cin >> n;
  10. for(int i=; i<n; i++)
  11. for(int j=; j<n; j++)
  12. cin >> a[i][j];
  13.  
  14. for(int k=; k<=n; k++)
  15. for(int i=k-, j=; i>=; i--, j++)
  16. if(k&) cout << a[i][j] << " ";
  17. else cout << a[j][i] << " ";
  18.  
  19. for(int k=n-; k>; k--)
  20. for(int i=n-, j=n-k; j<n ; i--, j++)
  21. if(k&) cout << a[i][j] << " ";
  22. else cout << a[j][i] << " ";
  23. }
往哪个方向走,和可以走多少步有规律可循。
矩阵维度为3的时候
右1 左下1 下1 右上2 右1 左下3
右1 右上 2 下1 左下1 右1
矩阵维度为4的时候
右1 左下1 下1 右上2 右1 左下3 下1 右上4
下1 左下3 右1 右上 2 下1 左下1 右1
不知道看出规律没有,
(1) 平行于坐标轴的方向和对角线方向的运动相互交替
(2) 平行于坐标轴运动时,右与下相互交替,正中间一次不交替
(3) 对角线运动的步长为类似1 2 3 4 3 2 1的序列

解法二

  1. #include "iostream"
  2.  
  3. using namespace std;
  4.  
  5. int a[][];
  6.  
  7. bool rightOrDown = false; // initial go right
  8. bool dlOrUr = false; // down left or up right, initial go down left
  9. bool parallelOrDiagonal = false; // initial parallel;
  10. int diagonalStep = ;
  11. int x = , y = ;
  12.  
  13. void moveParallel() {
  14. if(rightOrDown) x += ;
  15. else y += ;
  16. cout << a[x][y] << ' ';
  17. }
  18.  
  19. void moveDiagonal() {
  20. for(int s=; s<diagonalStep; s++) {
  21. if(dlOrUr) x -= , y += ;
  22. else x += , y -= ;
  23. cout << a[x][y] << ' ';
  24. }
  25. }
  26.  
  27. int main() {
  28. int n;
  29. cin >> n;
  30. for(int i=; i<n; i++)
  31. for(int j=; j<n; j++)
  32. cin >> a[i][j];
  33.  
  34. cout << a[x][y] << ' ';
  35. for(int i=; i<*n-; i++) {
  36. moveParallel();
  37. rightOrDown = !rightOrDown;
  38. moveDiagonal();
  39. dlOrUr = !dlOrUr;
  40. if(i<=n-) diagonalStep++;
  41. else diagonalStep--;
  42. if(i==n-) diagonalStep -= , rightOrDown = !rightOrDown;
  43. }
  44. }

  

CCF CSP 201412-2 Z字形扫描的更多相关文章

  1. CCF真题之Z字形扫描

    201412-2 问题描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag Scan).给定一个n×n的矩阵,Z字形扫描的过程如下图所示: 对于下面的4×4的矩阵, 1 5 ...

  2. [CCF] Z字形扫描

    CCF Z字形扫描 感觉和LeetCode中的ZigZag还是有一些不一样的. 题目描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag Scan).给定一个n×n的矩阵,Z ...

  3. CCF——Z字形扫描问题

    试题编号: 201412-2 试题名称: Z字形扫描 时间限制: 2.0s 内存限制: 256.0MB 问题描述: 问题描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag ...

  4. CCF系列之Z字形扫描(201412-2)

    试题编号:201412-2试题名称:Z字形扫描时间限制: 2.0s内存限制: 256.0MB 问题描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag Scan).给定一个n ...

  5. CSP201412-2:Z字形扫描

    引言:CSP(http://www.cspro.org/lead/application/ccf/login.jsp)是由中国计算机学会(CCF)发起的"计算机职业资格认证"考试, ...

  6. Z字形扫描(201412-2)

    问题描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag Scan).给定一个n×n的矩阵,Z字形扫描的过程如下图所示: 对于下面的4×4的矩阵, 1 5 3 9 3 7 5 ...

  7. Z字形扫描矩阵

    问题描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag Scan).给定一个n×n的矩阵,Z字形扫描的过程如下图所示: 对于下面的4×4的矩阵, 1 5 3 9 3 7 5 ...

  8. 201412-2 Z字形扫描(c语言)

    问题描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag Scan).给定一个n×n的矩阵,Z字形扫描的过程如下图所示: 对于下面的4×4的矩阵, 1 5 3 9 3 7 5 ...

  9. CCF201412-2 Z字形扫描 java(100分)

    试题编号: 201412-2 试题名称: Z字形扫描 时间限制: 2.0s 内存限制: 256.0MB 问题描述: 问题描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag ...

随机推荐

  1. oracle进阶之分析函数

    本博客是自己在学习和工作途中的积累与总结,纯属经验之谈,仅供自己参考,也欢迎大家转载,转载时请注明出处. http://www.cnblogs.com/king-xg/p/6797119.html 分 ...

  2. linux下安装shellinabox实现web登录服务器

    GitHub地址(含有文件下载和详细安装流程):https://github.com/shellinabox/shellinabox 这里我们使用的是redhat安装方法如下: 1.配置安装依赖环境 ...

  3. 动态规划:POJ No 2385 Apple Catching

    #include <iostream> #include <cstdio> #include <algorithm> #include <cstring> ...

  4. openresty/1.11.2.1性能测试

    测试数据 ab -n -c -k http://127.0.0.1/get_cache_value nginx.conf lua_shared_dict cache_ngx 128m; server ...

  5. 关于thinkpad安装win10操作系统

    thinkpad预装的是win8或者win10,会有自己的分区方式是GPT,所以会出现两个引导分区. F2进入tinkpad的bios,F12进入启动选项 我们用pe进入后,用分区工具删除两个分区,然 ...

  6. SVN自动更新-win平台

    把项目给外包做,他们天天整个ftp传来传去,上传一次还要到处翻View和Controller,还有漏传的情况,简直low到不行.看不下去了,就准备整个svn.虽然svn解决了上传的问题,但是自动发布还 ...

  7. 【转】.NET中的三种Timer的区别和用法

    最近正好做一个WEB中定期执行的程序,而.NET中有3个不同的定时器.所以正好研究研究.这3个定时器分别是: //1.实现按用户定义的时间间隔引发事件的计时器.此计时器最宜用于 Windows 窗体应 ...

  8. 【leetcode 简单】 第八十九题 赎金信

    给定一个赎金信 (ransom) 字符串和一个杂志(magazine)字符串,判断第一个字符串ransom能不能由第二个字符串magazines里面的字符构成.如果可以构成,返回 true :否则返回 ...

  9. Java编程思想 4th 第2章 一切都是对象

    Java是基于C++的,但Java是一种更纯粹的面向对象程序设计语言,和C++不同的是,Java只支持面向对象编程,因此Java的编程风格也是纯OOP风格的,即一切都是类,所有事情通过类对象协作来完成 ...

  10. HTML 解析 textarea 中的换行符

    用户在textarea中输入的换行符,传到后台,再返回前端,展示在div中. 如果需要div显示为与textarea 一致的效果,需添加: .detail { white-space: pre-lin ...