IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 前缀和,对数器与随机函数 -> 正文阅读

[数据结构与算法]前缀和,对数器与随机函数

  1. 数据结构分为物理结构与逻辑结构:
    逻辑结构: 有序表,链表,二叉树等
    物理结构: 紧密结构(连续结构),跳转结构
    ps: 所有的逻辑结构都是基于物理结构所形成的(单一或组合。)

  2. 基本数据结构:
    数组:便于寻址,不便于增加和删除
    链表:便于增加和删除,不便于寻址

稍微特殊一点的是,当数组很大时,可能会出现少量的跳转结构。 比如一亿长度的数组,1000万紧密存放在一起,然后尾指针指向下一个块的地址。

  1. 前缀和解法 --> 针对范围和问题
    给定一个数组,任意给出左右边界的值,,求以O(1)的时间复杂度返回累加和。
    (1)二维数组

(2)前缀和 --> 一维数组

public class Code01_PreSum {

	public static class RangeSum1 {

		private int[] arr;

		public RangeSum1(int[] array) {
			arr = array;
		}

		public int rangeSum(int L, int R) {
			int sum = 0;
			for (int i = L; i <= R; i++) {
				sum += arr[i];
			}
			return sum;
		}

	}

	public static class RangeSum2 {

		private int[] preSum;

		public RangeSum2(int[] array) {
			int N = array.length;
			preSum = new int[N];
			preSum[0] = array[0];
			for (int i = 1; i < N; i++) {
				preSum[i] = preSum[i - 1] + array[i];
			}
		}

		public int rangeSum(int L, int R) {
			return L == 0 ? preSum[R] : preSum[R] - preSum[L - 1];
		}

	}

}

随机函数

  1. JAVA中的随机函数 -> Math.random() --> 返回double类型 [0, 1)区间 等概率返回 (因为小数有精度,所以小数不是无穷的)

    –> [0, 1) --> [0, 8) 注意是double类型
    Math.random() * 8

    –>double [0, 1) --> (int)(Math.random() * K) --> int [0, K) --> int [0, K-1]

  2. 通过随机函数,可以得到任意范围的值 e.g. [16, 54] ([0, 1) * 39 + 16 )。
    Math.random * K + t

  3. 通过随机函数,实现不等概率返回,对于生成的任意数值,使得出现在[0 ,x]出现的概率的
    3.1 使得 [0, x) 的出现的概率为 x^2
    在这里插入图片描述
    3.2 使得[0, x)出现的概率为 1-(1 - x)^2
    答: Math.min(Math.random(), Math.random());

  4. 随机函数面试题
    4.1 从 1 ~ 5 随机 f(x) 到 1 ~ 7 g(x) 随机 等概率
    (1)1 2 --> 0; 3 重做; 4 5 --> 1 >>>>>>>>> 实现等概率01生成器
    (2)1 ~ 7共7个数字, 三位二进制可以满足(8种组合),对二进制进行移位 (x<<3 + x<<2 + x<<1) 属于范围 [0, 7]
    (3)封装函数, do { } while (x == 0) ----> 0重做,其余输出,从而完成 1 - 7等概率随机

    // 1~5随机 [1, 5] --> int [1, 6) --> int [0, 5) + 1
    public static int f() {
        return (int) (Math.random() * 5 + 1);
    }
    
    // 等概率01生成器
    public static int _01Generator() {
        int ans;
        do {
            ans = f();
        } while (ans == 3);
        return ans < 3 ? 0 : 1;
    }
    
    public static int g() {
        int ans;
        do {
            // 小心这里,记不清顺序 就乖乖把 括号加上,保证运算顺序
            ans = (_01Generator() << 2) + (_01Generator() << 1) + (_01Generator() << 0);
        } while (ans == 0);
        return ans;
    }
    

    OR
    (3)在第二步之后,将其变成 [0, 6]的等概率生成器(7重做), 然后 封装函数,使其返回值 +1 ,就变成了 [1, 7]。

    // return [0, 6]
    public static int g1() {
        int ans = 0;
        do {
            ans = (_01Generator() << 2) + (_01Generator() << 1) + (_01Generator() << 0);
        } while (ans == 7); // return [0,7] ----> [0, 6]
        return ans;
    }
    
    public static int g2(){
        return g1() + 1;
    }
    

    4.2 从 a ~ b 随机到 c ~ d 随机 - 等概率
    推荐使用后一种(3),基本方法相同。但latter更有普适性。(比如 3-19生成器 变为 128-150生成器,只需将[128,150] —> [0, 22] + 128,从而不需要生成过多二进制位)
    构造01等概率发生器(奇数重新生成,偶数直接对半分),寻找包含范围的二进制位数,调整对应的生成随机数范围
    4.3 从01不等概率到01等概率随机
    0 0 --> 重做
    1 1 --> 重做
    1 0 --> 50% --> 返回 1
    0 1 --> 50% --> 返回 0

    // 01不等概率生成器 0的概率为 P = 0.8, 1的概率为 0.2
    public static int x(){
        return Math.random() > 0.8 ? 0: 1;
    }
    
    // 转换为01等概率
    public static int y(){
        int ans;
        do{
            ans = x();
        }while( ans == x());
        return ans;
    }
    

根本思路: 重点:** 01等概率发生器 ** + do-while循环 使得部分重做(重新生成), 针对01进行二进制移位 (看看需要几个二进制位)+ do-while, over

对数器 - 生成随机样本自己做比对的机器

对数器是干什么用的?
对数器是用来调bug的,对数器让你不需要使用线上的测试,自己就可以调试代码。 可以随意控制样本大小。 大样本随机。

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-11-11 12:57:43  更:2021-11-11 12:59:09 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 1:18:03-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码