zoukankan      html  css  js  c++  java
  • [Algorithm] Print 2-D array in spiral order

    The idea to solve the problem is set five variable, first direction, we need to switch direction after we finish printing one row or one column.

    dir = (dir+1) % 4

    Then set four boundry, top, left, right, bottom:

      let results = [],
            dir = 0, //0: left -> right, 1: top -> bottom, 2: right -> left, 3: bottom -> top
            top = 0,
            bottom = arys.length - 1,
            left = 0,
            right = arys[0].length - 1;

    Each time finish printing a row or a column, modify the boundry accordingly:

    function PrintSpiralOrder (arys) {
      let results = [],
            dir = 0, //0: left -> right, 1: top -> bottom, 2: right -> left, 3: bottom -> top
            top = 0,
            bottom = arys.length - 1,
            left = 0,
            right = arys[0].length - 1;
      
      while (top <= bottom && left <= right) {
         if (dir === 0) {
           for (let i = left; i <= right; i++) {
             results.push(arys[top][i]);
           }
           top++;
         } else if (dir === 1) {
           for (let i = top; i <= bottom; i++) {
             results.push(arys[i][right]);
           }
           right--;
         } else if (dir === 2) {
           for (let i = right; i >= left; i--) {
             results.push(arys[bottom][i]);
           }
           bottom--;
         } else if (dir === 3) {
           for (let i = bottom; i >= top; i--) {
             results.push(arys[i][left]);
           }
           left++;
         }
        
         dir = (dir + 1) % 4;
      }
      
      return results;
    }
    
    const data = [
      [2,4,6,8],
      [5,9,12,16],
      [2,11,5,9],
      [3,2,1,8]
    ];
    
    const res = PrintSpiralOrder(data);
    console.log(res); // [ 2, 4, 6, 8, 16, 9, 8, 1, 2, 3, 2, 5, 9, 12, 5, 11 ]
  • 相关阅读:
    About cookie
    关于在Servlet中的Fileter
    看完这篇正则表达式,50岁的马化腾眼睛湿润了
    Tutorial中的hello2代码
    Development descriptor
    What is the Annotation?
    剖析容器的注入技术
    LDAP & Implentation
    RESTful levels、HATEOAS
    Mysql8.0导入数据时出错
  • 原文地址:https://www.cnblogs.com/Answer1215/p/10612493.html
Copyright © 2011-2022 走看看