zoukankan      html  css  js  c++  java
  • 算法

    1.     一列数的规则如下: 1、1、2、3、5、8、13、21、34...... 求第30位数是多少 , 用递归算法实现。

    该数列为斐波那契数列,规律为第三位为前两位之和。

      

    2.     求表达式的值,写出一种或几种实现方法: 1-2+3-4+……+m

     

    3.     编程实现一个冒泡排序算法

    复制代码
    /**
         * 冒泡排序:每次只能确定一位最大的,放置数组末尾 ,下次忽略已经确定的最大值继续比较
         * 优点:稳定
         * 缺点:效率底下(重复相邻数据比较,且每次比较都会进行位置置换)
         * @param arr
         * @return
         */
        public static int[] bubbleSort(int[] arr) {
            int len = arr.length; // 数组长度
            for (int i = 0; i < len; i++) { // 遍历数组,用来限制内循环次数
                for (int j = 1; j < len - i; j++) { // 内循环,依次减少1个次数(即为比较几次,就忽略后几位)
                    if (arr[j - 1] > arr[j]) { // 如果前一位大于后一位,即 前>后,需要交换位置
                        int k = arr[j - 1]; // 把前面的先缓存起来
                        arr[j - 1] = arr[j]; // 让前面的等于后一位
                        arr[j] = k; // 后一位等于前一位之前的缓存值
                    }
                }
            }
            return arr;
        }
    复制代码

    4.     编程实现一个选择排序算法

    复制代码
     /* 选择排序,从当前位(0开始)开始和下一位依次比较,找到最小元素,让当前位和最小元素换位,其他元素不变
           * 继续从当前位的下一位开始,依次查找最小元素并换位,直至最后一位
           * @param arr
           * @return*/
            public static int[] selectSort(int[] arr)
            {
                int len = arr.length;
                for (int i = 0; i < len; i++)
                {
                    int min = arr[i]; // 每次都认为当前队列第一位为最小值,进行缓存
                    int index = i;       // 缓存最小值(变化)坐标
                    for (int k = i + 1; k < len; k++)
                    { // 向后比较
                        if (arr[k] <= min)
                        { // 如果后一个小于等于前一个
                            min = arr[k]; // 更换最小值
                            index = k; // 变更最小值坐标
                        }
                    }
                    if (min == arr[i]) // 相等则不变化,默认保留当前队列第一个为最小
                        continue;
                    // 循环完毕,找出了最小值的坐标,即为index,把当前坐标i元素和最小元素换位
                    int k1 = arr[i];
                    arr[i] = arr[index];
                    arr[index] = k1;
                }
                return arr;
            }
    复制代码

    5.     编程实现一个插入排序算法

    复制代码
    /**
         * 插入排序,默认第一位已经排好序,从第二位开始依次向前比较,确定自己的位置后插入,即前一位小余或等于当前,且后一位大于当前。
         * 插入后,自己新位置后面的元素依次向后移位, 完成一轮插入排序
         * @param arr
         * @return
         */
        public static int[] insertSort(int[] arr) {
            int len = arr.length;
            for (int i = 1; i < len; i++) {
                if (arr[i - 1] > arr[i]) {
                    int k = arr[i];
                    int j = i;
                    while (j > 0 && arr[j - 1] > k) {
                        arr[j] = arr[j - 1];
                        j--;
                    }
                    arr[j] = k;
                }
            }
            return arr;
        }
    复制代码
  • 相关阅读:
    洛谷 P1786 帮贡排序 题解
    Bayes++ Library入门学习之熟悉UKF相关类
    Bayes++ Library入门学习之熟悉class-Bayesian_filter_base(2)
    Bayes++ Library入门学习之熟悉class-Importance_resampler
    Bayes++ Library入门学习之熟悉class-Bayesian_filter_base(1)
    Bayes++ Library入门学习之熟悉namespace
    CMake入门之创建一个基于PCL的最小工程
    CUDA学习之从CPU架构说起
    #pragma 预处理指令详解
    C++中inline函数
  • 原文地址:https://www.cnblogs.com/huhaihua/p/4125656.html
Copyright © 2011-2022 走看看