当前位置: 首页 > news >正文

dw网站建设的数据库企业站seo价格

dw网站建设的数据库,企业站seo价格,wordpress 4.1 下载,为什么做的网站打开自动缩放原题链接 难度:middle\color{orange}{middle}middle 题目描述 给你一个单链表,随机选择链表的一个节点,并返回相应的节点值。每个节点 被选中的概率一样 。 实现 SolutionSolutionSolution 类: Solution(ListNodehead)Solution…

原题链接

难度:middle\color{orange}{middle}middle


题目描述

给你一个单链表,随机选择链表的一个节点,并返回相应的节点值。每个节点 被选中的概率一样

实现 SolutionSolutionSolution 类:

  • Solution(ListNodehead)Solution(ListNode head)Solution(ListNodehead) 使用整数数组初始化对象。
  • intgetRandom()int getRandom()intgetRandom() 从链表中随机选择一个节点并返回该节点的值。链表中所有节点被选中的概率相等。

示例:

输入
["Solution", "getRandom", "getRandom", "getRandom", "getRandom", "getRandom"]
[[[1, 2, 3]], [], [], [], [], []]
输出
[null, 1, 3, 2, 2, 3]解释
Solution solution = new Solution([1, 2, 3]);
solution.getRandom(); // 返回 1
solution.getRandom(); // 返回 3
solution.getRandom(); // 返回 2
solution.getRandom(); // 返回 2
solution.getRandom(); // 返回 3
// getRandom() 方法应随机返回 1、2、3中的一个,每个元素被返回的概率相等。复制示例输入

提示:

  • 链表中的节点数在范围 [1,104][1, 10^{4}][1,104]
  • −104<=Node.val<=104-10^{4} <= Node.val <= 10^{4}104<=Node.val<=104
  • 至多调用 getRandomgetRandomgetRandom 方法 10410^{4}104

进阶:

  • 如果链表非常大且长度未知,该怎么处理?
  • 你能否在不使用额外空间的情况下解决此问题?

算法1

(记录所有链表元素)

我们可以在初始化时,用一个数组记录链表中的所有元素,这样随机选择链表的一个节点,就变成在数组中随机选择一个元素。

复杂度分析

  • 时间复杂度:初始化为 O(n)O(n)O(n),随机选择为 O(1)O(1)O(1),其中 nnn 是链表的元素个数。

  • 空间复杂度 : O(n)O(n)O(n),我们需要 O(n)O(n)O(n) 的空间存储链表中的所有元素。

C++ 代码

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode() : val(0), next(nullptr) {}*     ListNode(int x) : val(x), next(nullptr) {}*     ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/
class Solution {
public:vector<int> arr;Solution(ListNode* head) {while (head) {arr.emplace_back(head->val);head = head->next;}}int getRandom() {return arr[rand() % arr.size()];}
};/*** Your Solution object will be instantiated and called as such:* Solution* obj = new Solution(head);* int param_1 = obj->getRandom();*/

算法2

(蓄水池抽样)

nnn 个元素,从中选 mmm 个,使得每个元素被选中的概率都是 m/nm/nm/n,该题中,m=1m = 1m=1

用一个变量 rrr 存储当前存储选择的数是多少。

  • 如果只有一个元素,则一定选择该数,r=xr = xr=x
  • 如果有两个数,换成当前数的概率为 1/21/21/2
  • 如果有三个数,换成当前数的概率为 1/31/31/3
  • 以此类推,这样,每个数被随机到的概率是一样的,且和 nnn 的大小无关。

复杂度分析

  • 时间复杂度:初始化为 O(1)O(1)O(1),随机选择为 O(n)O(n)O(n),其中 nnn 是链表的元素个数。

  • 空间复杂度 : O(1)O(1)O(1),我们只需要常数的空间保存若干变量。

C++ 代码

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode() : val(0), next(nullptr) {}*     ListNode(int x) : val(x), next(nullptr) {}*     ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/
class Solution {
public:ListNode* dummy;Solution(ListNode* head) {dummy = head;}int getRandom() {// c 代表获奖人数,n代表总人数int c = -1, n = 0;for (auto p = dummy; p; p = p->next) {n ++; // 人数加1if (rand() % n == 0) c = p->val;}return c;}
};/*** Your Solution object will be instantiated and called as such:* Solution* obj = new Solution(head);* int param_1 = obj->getRandom();*/
http://www.wangmingla.cn/news/163423.html

相关文章:

  • 太原论坛昆明seo关键词
  • 架设网站flash不显示管理培训
  • jsp 数据库做网站济南网站建设方案
  • 天天新网站网站推广seo是什么
  • 简答网站建设流程有哪些站长工具ip地址
  • 把自己做的网页变成网站独立站seo
  • 专做ppt的网站专注于seo顾问
  • 响应式网站建设报价单推广赚钱项目
  • 仙游哪里可以做网站的谷歌外贸平台叫什么
  • 做直播导航网站有哪些八种营销模式
  • 资金盘网站开发简短的软文范例
  • 怎么自己做网页链接seo推广培训课程
  • 海南网站策划软文素材网站
  • 动态网站开发实例教程网站建设黄页免费观看
  • 做独立网站需要软件吗市场调研报告怎么写的
  • 广阳区建设局网站seo搜索引擎优化是什么
  • 北京优质网站制作信息流优化师工作内容
  • 德州做网站优化苏州seo建站
  • 网站建设招标公示营销型网站的类型有哪些
  • 学校文化建设聚奇网站新手怎么学电商运营
  • 免费查公司的网站手机百度一下
  • 网站开发可选的方案有外贸互联网推广的
  • 现在做网站建设的公司多么优秀软文范例
  • 免费下载app软件正版上海网站快速优化排名
  • 诸暨网站制作企业网络宣传推广方案
  • 郑州企业网站建站模板重庆seo网页优化
  • 做执法设备有哪些网站原画培训机构哪里好
  • 网站建设系统设计百度手机助手下载2021新版
  • 网站建设后运维合同百度高级搜索入口
  • 渭南做网站公司企业网站推广注意事项