zoukankan      html  css  js  c++  java
  • 数组算法经典实例

    按照以下步骤编码:

    1.分配两个5*5数组a和b,数组a按照以下所示赋值,
    5,85,4,2,68
    18,82,75,41,14
    79,47,38,1,47
    1,2,14,65,13
    96,87,32,14,21

    对于数组中的每一个元素a[i][j],从它的相邻元素中选取中间值填入b[i][j]中,打印数组b.

    例如:a[0][2]的相邻元素为85,82,75,41,2,升序(降序也可以)排列后为:2,41,75,82,85,取中间值方法:

    中间值索引 = 相邻元素个数/2

    即5/2 = 2,中间值为75,将75填入b[0][2]位置。

    a[2][1]的相邻元素为78,82,75,79,38,1,2,14,排序后为1,2,14,38,75,78,79,82,中间值为75,填入b[2][1]。

    以此类推,求出b[i][j]并打印。

    答案:

    
    
    package com.example.demo;
    
    import java.util.ArrayList;
    import java.util.List;
    
    /**
     * @author tobiasy
     */
    public class Test {
        public static int getResult(int m,int n) {
            int[][] a = {
                    {5,85,4,2,68},
                    {18,82,75,41,14},
                    {79,47,38,1,47},
                    {1,2,14,65,13},
                    {96,87,32,14,21}
            };
            int[] x = {m-1,m,m+1};
            int[] y = {n-1,n,n+1};
            List<Integer> list = new ArrayList<>();
            for (int i = 0; i < 3; i++) {
                for (int j = 0; j < 3; j++) {
                    if (x[i] >= 0 && y[j] >= 0 && x[i] < 5 && y[j] < 5) {
                        if (i==1&&j==1) {
    
                        }else {
                            list.add(a[x[i]][y[j]]);
                        }
                    }
                }
            }
            int[] result = new int[list.size()];
            for (int i = 0; i < list.size(); i++) {
                int num = list.get(i);
                result[i] = num;
            }
            for (int i = 0; i < result.length; i++) {
                for (int j = 0; j < result.length; j++) {
                    if (result[i] > result[j]) {
                        int temp = result[i];
                        result[i] = result[j];
                        result[j] = temp;
                    }
                }
            }
            return result[result.length/2];
        }
    
        public static void main(String[] args) {
            int[][] b = new int[5][5];
            for (int i = 0; i < 5; i++) {
                for (int j = 0; j < 5; j++) {
                    int res = getResult(i,j);
                    b[i][j] = res;
                }
            }
        //打印方式可自行定义
            for (int i = 0; i < 5; i++) {
                for (int j = 0; j < 5; j++) {
                    System.out.print(b[i][j]+",");
                }
                System.out.println();
            }
        }
    
    }
    
    
    
    
     

    运行结果:

    82,18,75,41,14,
    79,38,38,14,41,
    18,18,41,38,14,
    79,38,32,14,21,
    2,14,14,21,14,

  • 相关阅读:
    关于json的一些自己的了解
    .Net Core 控制台 使用Topshelf 加入DI(服务注册)
    【Linux】Centos7 入门到放弃记录
    【git】.net core +git减少包体积
    【git-bug累计】实践中git命令出现的问题总结
    [Bug] uni-app 上下切屏tabbar底部导航显示问题
    .NetCore2.0 vue-element-admin 出现的错误记录
    黑盒测试总结
    sql 学习笔记
    Linux 学习笔记
  • 原文地址:https://www.cnblogs.com/tobiasy/p/8494221.html
Copyright © 2011-2022 走看看