面试算法题2

简介: 版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/1536661 面试算法题2package myfile;/** * 请用Java语言写一个函数printArray(int[][] aData),该函数将一个二维数组以顺时针螺旋的方式打印出来。
版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/1536661

面试算法题2

package myfile;
/**
 * 请用Java语言写一个函数printArray(int[][] aData),该函数将一个二维数组以顺时针螺旋的方式打印出来。
 * 例如,对数组:
 * 1 2 3 4 5
 * 14 15 16 17 6
 * 13 20 19 18 7
 * 12 11 10 9 8
 *
 * 打印出来的序列应该是:1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20
 * @author J
 *
 */
public class Mymethod2 {

 public static int[][] arr={{1,2,3,4,5},{14,15,16,17,6},{13,20,19,18,7},{12,11,10,9,8}};
 public static void main(String[] args) {
  Mymethod2 program=new Mymethod2();
  program.printArray(arr);  

 }
 public void printArray(int[][] aData){
  Character[] dire={'E','S','W','N'};
  //System.out.println(dire.length);
  char p=dire[0];
  Boolean loop1=true;
  int h1=0,h2=aData[0].length-1;
  int v1=0,v2=aData.length-1;
  //System.out.println(v2);
  int i=0;
  while(loop1){
   p=dire[i];
   if(v1>v2 || h1>h2) loop1=false;
   if(p=='E'){
    forwardPrint(h1,h2,v1,v1,aData);
    //++h1;
    ++v1;
   }
   if(p=='S'){
    forwardPrint(h2,h2,v1,v2,aData);
    //--v2;
    --h2;
   }
   if(p=='W'){
    reversePrint(h1,h2,v2,v2,aData);
    //--h2;
    --v2;
   }
   if(p=='N'){
    reversePrint(h1,h1,v1,v2,aData);
    //++v1;
    ++h1;
   }
   ++i;
   if(i==4) i=0;
  }
 }
 public void forwardPrint(int a1, int a2, int b1, int b2, int[][] c){
  for(int j=b1;j<=b2;j++){
   for(int k=a1;k<=a2;k++){
    System.out.print(c[j][k]+",");    
   }
  }
 }
 public void reversePrint(int a1, int a2, int b1, int b2, int[][] c){
  for(int j=b2;j>=b1;j--){
   for(int k=a2;k>=a1;k--){
    System.out.print(c[j][k]+",");    
   }
  }
 }

}

--------------------------------------------------------------------------------------------------------------

输出结果:

1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,

补充:最后一个逗号未作处理;另外,算法可以再优化。

目录
相关文章
|
1月前
|
开发框架 算法 搜索推荐
C# .NET面试系列九:常见的算法
#### 1. 求质数 ```c# // 判断一个数是否为质数的方法 public static bool IsPrime(int number) { if (number < 2) { return false; } for (int i = 2; i <= Math.Sqrt(number); i++) { if (number % i == 0) { return false; } } return true; } class Progr
58 1
|
17天前
|
负载均衡 算法 应用服务中间件
面试题:Nginx有哪些负载均衡算法?Nginx位于七层网络结构中的哪一层?
字节跳动面试题:Nginx有哪些负载均衡算法?Nginx位于七层网络结构中的哪一层?
32 0
|
1月前
|
算法
覃超老师 算法面试通关40讲
无论是阿里巴巴、腾讯、百度这些国内一线互联网企业,还是 Google、Facebook、Airbnb 等硅谷知名互联网公司,在招聘工程师的过程中,对算法和数据结构能力的考察都是重中之重。本课程以帮助求职者在短时间内掌握面试中最常见的算法与数据结构相关知识点,学会面试中高频算法题目的分析思路,同时给大家从面试官的角度来分析算法题的解答技巧,从而更有效地提升求职者的面试通过率。
15 3
覃超老师 算法面试通关40讲
|
1月前
|
存储 算法
【数据结构与算法】【腾讯阿里链表面试题】算法题--链表易懂版讲解
【数据结构与算法】【腾讯阿里链表面试题】算法题--链表易懂版讲解
|
1月前
|
存储 机器学习/深度学习 算法
python常用算法,新手必会,面试必出
python常用算法,新手必会,面试必出
37 0
|
1月前
|
存储 算法 Java
【数据结构与算法】2、链表(简单模拟 Java 中的 LinkedList 集合,反转链表面试题)
【数据结构与算法】2、链表(简单模拟 Java 中的 LinkedList 集合,反转链表面试题)
43 0
|
2月前
|
机器学习/深度学习 算法 Java
递归算法还有哪些是你不知道的----【探讨Java经典遍历问题和面试题】
递归算法还有哪些是你不知道的----【探讨Java经典遍历问题和面试题】
32 1
|
3月前
|
存储 缓存 算法
数据结构与算法面试题:实现一个 LRU 缓存,支持如下操作:获取值、更新值、删除键值对和插入键值对
数据结构与算法面试题:实现一个 LRU 缓存,支持如下操作:获取值、更新值、删除键值对和插入键值对
28 0
|
3月前
|
存储 算法 Java
数据结构和算法面试题:给定一个整数数组 nums,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。
数据结构和算法面试题:给定一个整数数组 nums,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。
42 0
|
3月前
|
算法 Java C++
数据结构与算法面试题:实现一个函数 fill(int[] a, int n, int v),使其将大小为 n 的数组 a 填满为 v。
数据结构与算法面试题:实现一个函数 fill(int[] a, int n, int v),使其将大小为 n 的数组 a 填满为 v。
16 0