首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

数据结构-散列表(下)

前驱和后继指针是为了将结点串双向链表,hnext 指针是为了将结点串散列表拉链。 Redis 有序集合 跳表那一节,讲到有序集合操作时,我稍微做了些简化。...我来具体分析一下,为什么这段代码会按照这样顺序来打印。 每次调用 put() 函数,往 LinkedHashMap 添加数据时候,都会将数据添加到链表尾部。...散列表这种数据结构虽然支持非常高效数据插入、删除、查找操作,但是散列表数据都是通过散列函数打乱之后无规律存储。也就说,它无法支持按照某种顺序快速地遍历数据。...、 课后思考 今天讲几个散列表和链表结合使用例子里,我们用都是双向链表。如果把双向链表改成单链表,还能否正常工作呢?为什么呢?...删除一个元素时,虽然能 O(1) 找到目标结点,但是要删除该结点需要拿到前一个结点指针,遍历到前一个结点复杂度会变为 O(N),所以用双链表实现比较合适。

54420

【图解数据结构与算法】LRU缓存淘汰算法面试时到底该怎么写

因为我们链表是双向链表,双向链表可以通过前驱指针O(1)时间复杂度获取前驱结点,所以双向链表,删除结点只需要O(1)时间复杂度。...hash表这种数据结构虽然支持非常高效数据插入、删除、查找操作,但hash表数据都是通过hash函数打乱之后无规律存储。也就说,它无法支持按照某种顺序快速地遍历数据。...如果把双向链表改成单链表,还能否正常工作呢?...删除一个元素时,虽然能 O(1) 找到目标结点,但是要删除该结点需要拿到前一个结点指针,遍历到前一个结点复杂度会变为 O(N),所以用双链表实现比较合适。...查找按照积分从小到大排名 x 位到 y 位之间猎头 ID 列表 以积分排序构建一个跳表,再以猎头 ID 构建一个散列表: 1)ID 散列表中所以可以 O(1) 查找到这个猎头; 2)积分以跳表存储

78020
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【图解数据结构与算法】LRU缓存淘汰算法面试时到底该怎么写

    因为我们链表是双向链表,双向链表可以通过前驱指针O(1)时间复杂度获取前驱结点,所以双向链表,删除结点只需要O(1)时间复杂度。...hash表这种数据结构虽然支持非常高效数据插入、删除、查找操作,但hash表数据都是通过hash函数打乱之后无规律存储。也就说,它无法支持按照某种顺序快速地遍历数据。...如果把双向链表改成单链表,还能否正常工作呢?...删除一个元素时,虽然能 O(1) 找到目标结点,但是要删除该结点需要拿到前一个结点指针,遍历到前一个结点复杂度会变为 O(N),所以用双链表实现比较合适。...查找按照积分从小到大排名 x 位到 y 位之间猎头 ID 列表 以积分排序构建一个跳表,再以猎头 ID 构建一个散列表: 1)ID 散列表中所以可以 O(1) 查找到这个猎头; 2)积分以跳表存储

    45820

    居然还有这种操作?

    曾经以为C语言已经深入骨髓,融入血液,直到看到一到这样面试题,才发现学海无涯: ? 请问代码10、11和12行,分别会输出什么?...这个结果分析如下: 1,首先,a值是0x100,这个没什么毛病。 2,其次,p值是0xbffa12e4是变量a地址,直接输出,也没什么毛病。...毕竟,8行代码就是让变量a地址,存放到指针p里面。...3,再其次,*p输出结果就有点不可理解了,按道理,*p值得就是p所指向目标,也就是变量a,那应该输出 0x100 才对,但结果却依然是a地址,仿佛目标引用符 * 不起作用了?...! 造成指针目标引用符失效原因,5行。p定义说明了p是一个函数指针函数指针虽然也是指针,但他跟普通指针有一个极大区别,那就是指针目标引用符*,对他是无效

    25620

    【007期】JavaSE面试题(七):异常

    开篇介绍 大家好,我是Java面试题库提裤姐,今天这篇是面试系列第七篇,主要总结了JavaSE异常类相关面试题,在后续,会沿着第一篇开篇知识线路一直总结下去,做到日更!...Q: 说一下Java异常体系? ? Q: Error和Exception区别? Error(错误): 系统错误,是程序编译时出现错误,只能通过修改程序才能修正。...(1)java.lang.NullPointerException 空指针异常;出现原因:调用了未经初始化对象或者是不存在对象。...代码走到 3 行时候遇到了一个 MathException,这时第四行代码就不会执行了,代码直接跳转到 catch语句中,走到 6 行时候,异常机制有这么一个原则如果在 catch 遇到了...return 或者异常等能使该函数终止的话那么有 finally 就必须先执行完 finally 代码块里面的代码然后再返回值。

    39110

    c++ostream类超详细说明

    ,而带参数构造函数则是公有的,根据public和protected功能,我们要定义一个ostream对象,必须要在参数传入streambuf类型指针才可以,否则会报编译错误。...).put(c).put('\n'); return 0; } 这里因为put函数返回是ostream&类型,所以可以连着使用put函数代码编译后执行结果如下: [root@mylinux.../a.out c=X [root@mylinux ~]# 4.write函数 ostreamwrite函数原型如下: //将__s指针所指向字符串复制出来并插入到缓冲区,最多插入_...("aaa\n", 4); return 0; } good函数是ostream继承于父类ios一个成员函数,它用来检查流状态是否正常正常则返回true。...按照我理解,ofstream往文件写入数据时,数据实际上是先写到缓冲区,并没有写到文件中去,所以需要调用一个flush,来确保数据会从缓冲区写到输出设备,也就是文件中去。

    3K30

    详解并发下HashMap以及JDK8优化

    2.多线程put后可能导致get死循环 造成死循环原因是多线程进行put操作时,触发了HashMap扩容(resize函数),出现链表两个结点形成闭环,导致死循环。...下图为JDK8put操作流程,详情请自行查看源码。 ? 单线程resize过程 ? 首先我们把resize函数transfer()关键代码贴出来: while(null !...3.扩容机制优化 JDK7,对所有链表进行rehash计算;JDK8,实际上也是通过取余找到元素所在数组位置,取余方式putVal里面:i = (n - 1) & hash。...在这n+1位里面,如果1位是0,那么扩容前后这个key位置还是相同位置(因为hash相同,并且余数1位是0,和之前n位时候一样,所以余数还是一样,位置就一样了);如果这n+1第一位是1...这样子就减少了移动所有数据带来消耗。(慢慢读两遍,想明白了,就觉得这个其实不看图更好理解) ? 常见FAQ HashMap扩容条件 查看JDK7源码put函数,然后跳转到addEntry函数

    1.1K40

    Linux文件基础IO

    正确返回值是文件描述符(其实就是一个小整数,下面会说明由来),错误是-1。 注意:使用open时,如果不存在该文件,一定要注意第二个参数要传什么参数,第三个参数是必须要传,不然就是错误文件。...,要用O_RDWR,因为只读和只写特殊位都是一个位置,只不过是相反,也就是说总会有一个不起作用下面写起了作用就代表读不会起作用。...缓冲区 首先来看一段代码: 打印正常 重定向正常 这时我加了一个fork创建子进程。 打印正常 这个内容是意料之外。...这就是为什么刷新缓冲区函数要传入文件指针,因为里面有缓冲区!...那么:使用重定向之后,写入文件不是显示器,而是文件,所以就变成全缓存,之前三天C函数虽然结尾有\n,但是没有写满stdout。

    1.3K00

    c++面试选择题_C语言经典笔试题

    从基类继承来纯虚函数派生类仍是虚函数。 抽象类不仅包括纯虚函数,也可包括虚函数。抽象类必须用作派生其他类基类,而不能用于直接创建对象实例。但仍可使用指向抽象类指针支持运行时多态性。...这时,被调函数形参就成为原来主调函数实参变量或对象一个别名来使用,所以在被调函数对形参变量操作就是对其相应目标对象(主调函数操作。...(3)使用指针作为函数参数虽然也能达到与使用引用效果,但是,在被调函数同样要给形参分配存储单元,且需要重复使用”*指针变量名”形式进行运算,这很容易产生错误且程序阅读性较差;另一方面,主调函数调用点处...两个不同类型指针之间可以强制转换(用reinterpret cast)。C#是类型安全。 16. main 函数执行以前,还会执行什么代码? 答案:全局对象构造函数会在main 函数之前执行。...为什么? 答案:正确 这个 sizeof是编译时运算符,编译时就确定了 ,可以看成和机器有关常量。 25题:引用与指针有什么区别?

    1.1K10

    函数

    以该类为基类派生类,也不能出现这种非虚同名同返回值同参数个数同参数类型函数。   为什么函数必须是类成员函数:   虚函数诞生目的就是为了实现多态,类外定义虚函数毫无实际用处。   ...为什么构造函数不能为虚函数:   因为如果构造函数为虚函数的话,它将在执行期间被构造,而执行期则需要对象已经建立,构造函数所完成工作就是为了建立合适对象,因此没有构建好对象上不可能执行多态(虚函数目的就在于实现多态性...注意:当基类构造函数内部有虚函数时,会出现什么情况呢?结果是构造函数,虚函数机制不起作用了,调用虚函数如同调用一般成员函数一样。当基类析构函数内部有虚函数时,又如何工作呢?...因此,析构函数,虚函数机制也是不起作用。   C++函数作用主要是实现了多态机制。关于多态,简而言之就是用父类型别的指针指向其子类实例,然后通过父类指针调用实际子类成员函数。...虽然在上面的图中我们可以看到子类虚表中有Derive自己函数,但我们根本不可能使用基类指针来调用子类自有虚函数:   Base1 *b1 = new Derive();   b1->f1();

    85131

    【C++】初识类和对象

    接下来就来看看类是如何定义。 3. 类访问限定符 定义一个类,使用时为什么会出现下面的问题呢? 这个是因为C++中有三种访问限定符。...对象包含类各个成员 缺陷:每个对象成员变量是不同,但是调用同一份函数,如果按照此种方式存储,当一个类创建多个对象时,每个对象中都会保存一份代码,相同代码保存多次,浪费空间。...C++通过引入this指针解决该问题,即:C++编译器给每个“非静态成员函数“增加了一个隐藏指针参数,让该指针指向当前对象(函数运行时调用该函数对象),函数体中所有“成员变量”操作,都是通过该指针去访问...来看看这个代码: 这里i和j是一起放在栈上。p也是栈上。这里p存指针常量区,这里const。 排除c,static全局静态区,显然this不是。...这里是传一个this空指针,没有解引用,没有问题。 1.下面程序编译运行结果是?

    13910

    Java IAQ:很少被回答问题

    但也存在一些特例,比如:不管choice值是什么,下面代码finally语句就不会被执行。 Q:类C一个方法m调用this.getClass()是不是永远返回C? 不。...Q:我尝试向super传一个方法,但有时候它不正常工作为什么下面是针对上述问题一段简化后代码示例: 你需要在调用super时候非常小心,并且一定要清楚super方法究竟会做什么。...一个类,实例变量初始化代码可以出现在3个地方: 当你写下new C()时,初始化顺序是这样(不考虑内存不够情况): 1、调用C父类构造函数(除非C是Object这个类,因为Object没有父类...善用setter方法是件好事,因为创建对象时需要修改变量往往之后也可能要修改,所以为什么要在构造函数和setter方法里写一样代码呢?...不复存在是程序员失去了对结构体/类分配在堆或栈选择权。Java,所有对象都被分配到堆,这就是为什么指针不需要语法标记符(如*)——Java,如果它是一个对象引用,那它就是指针

    61920

    【C++】初识面向对象:类与对象详解

    为了方便演示将采用第一种,大家在后序工作尽量使用第二种方式,体现了面对对象编程封装特性,提高代码可维护性。...,将对象地址作为实参传递给this形参,所以对象不存储this指针this指针是成员函数第一个隐含指针形参,将对象地址作为实参传递,对此函数参数个数为n+1个,一般情况由编译器通过exc寄存器,...结构体,成员内存对齐是由编译器决定,通常会按照平台和编译器规则进行对齐2.为什么内存对齐内存对齐是为了提高内存访问效率和系统性能。...相反,编译器会将空对象地址传递给this指针,但是成员函数内部要特别小心处理这种情况,以避免潜在未定义行为。8.this指针存在哪里虽然this被const修饰,但是不存储常量区。...C++cosnt修饰变量本身不存储常量区,而是栈上。this作为一个形参,有些编译可能用寄存器存储。可能频繁使用this不如放在寄存器上。9.关于两道题目// 1.下面程序编译运行结果是?

    9800

    c++endl操作符以及它兄弟们

    1.endl操作符实现 标准库头文件,我找到了endl操作符重载函数,如下: template inline...那么endl是怎么与<<操作符关联起来呢,我们ostream头文件ostream类声明又发现了以下代码: __ostream_type& operator<<(__ostream_type...操纵算子分为两类,一类是无参,定义ios_base.h头文件,还有一类是有参,定义iomanip头文件。...const std::tm类型指针,第二个类型是对时间进行格式化格式字符串 根据第二个参数指定格式输出tm数据 get_time 第一个参数是const std::tm类型指针,第二个类型是对时间进行格式化格式字符串...根据第二个参数指定格式把数据填充到tm 带参数这些操作函数,前面6个其实是比较好理解,但是后面四个用起来就比较麻烦了,而且单独使用也是不起作用下面我们就后面四个操作符,看一下使用案例,如下

    41420

    ftp登陆命令「建议收藏」

    这会让很多人困扰,为什么呢?不要忘记了,其实你最后代码脚本是EOF,所以,不管你前面自动FTP传送还是获取都是失败,其实这个正常结束符号让这个脚本“正常结束”了,因此,$?返回值就是0了。...get命令下载文件将保存在本地计算机工作目录下。该目录是启动FTP时盘符C:后显示目录。如果想修改本地计算机工作目录,可以使用 lcd 命令。...·netrc应包含基本命令 FTP中有几十个命令,.netrc应该设置大致有如下几条: 1.default loginpassword   Internet,存在大量匿名ftp...5.hash on   ftphash命令,使得进行文件传输时,每传输1千字节,屏幕上显示一个”#”号,用户通过观看屏幕上”#”号,可以很直观地看到传输速度快慢,以及文件传输完成情况,以决定进一步操作...prompt off idle 7200 (空行)   1行意为缺省情况下,进入anonymous帐户,并以自己电子邮件地址为口令;2行至8行定义了宏init,该宏所有

    6.1K10

    SAS-Macro 那些语句(二)

    局部宏变量是只作用在当前Macro内,离开了这个Macro这个宏变量就不起作用了~所谓作用,指的是赋值值与是否存在该宏变量...一般情况下,如果这个宏变量之前没有开放式代码(所谓开放式代码指的是没有被.../*首先:我们开放式代码定义一个宏变量*/ %let macvar1=WO SHI YI GE HAO REN; /*放在封闭式代码再一次定义宏变量*/ %macro test; %let...(宏外):&macvar1.; /*执行宏宏变量值*/ %test; /*执行宏后宏变量值*/ %put NOTE:第三个解析值(宏外):&macvar1.; 看上面的代码:先猜猜以此解析三个宏变量值是啥...那么还是来看看几行代码 /*首先:我们开放式代码定义一个宏变量*/ %let macvar1=WO SHI YI GE HAO REN; %macro test; %put NOTE:1个解析值(...; %test4; %put NOTE:2个解析值(宏外):&macvar1.; 全局宏变量实际写宏作用多么~答案也是显然,非常常用,让宏变量不同组件传递...就想下面一个rtf输出宏,用都个组成部分

    1.6K21

    【C++】类与对象理解和学习(上)

    两种定义方式: 一种是将成员函数定义类里面(编译器可能会当成内联函数处理) 另一种是将成员函数声明与定义分离(工作推荐第二种) 这里需要注意是,定义成员函数以及成员变量时,不需要考虑定义先后顺序...,也就是说,即使成员变量放在成员函数下面,成员函数依然可以使用成员变量。...类对象存储方式 实际上,成员函数虽然是定义,但是它并不存储类里,假如它是存储,而每个实例化后对象都各自拥有各自成员函数,则会造成严重资源浪费,因为成员函数就好比小区健身器材、公共厕所等公共共有的设施...就比如说下面的一个例子: class Date { public:     //成员函数(公有的,存储代码) void Init(int year,int month,int day)...= nullptr; //不能仅凭借*以及->来断定就是空指针解引用 //d1->Print1();//程序正常运行 //d1->Print2();//程序崩溃,因为函数内容涉及到了空指针解引用

    47840

    Rust避坑Java空指针异常

    虽然提高了代码可读性和健壮性,但需要额外工具支持。Java6和7没有引入与null相关新特性,空指针异常仍是Java程序员要面临问题。...Java让程序员不必操心指针复杂性,是广受欢迎编程语言。如何运行代码清单2-1Java代码?❓如何运行代码清单2-1Java代码?...18行错误地使用Optional,直接调用get()方法而不检查值是否存在。21-24行是主方法。22行调用printName(1),这会正常工作。... Rust 函数最后一个表达式值会被隐式地作为函数返回值。这就是为什么代码清单2-33-7行,没有看到 return 关键字,但函数仍然能够返回值。...这就是为什么最后一个表达式可以作为返回值原因。Rust 确实有 return 语句。它可以用于显式地从函数返回值,尤其是函数中间部分提前返回时。

    28761

    C++引用高级使用!

    这时,被调函数形参就成为原来主调函数实参变量或对象一个别名来使用,所以在被调函数对形参变量操作就是对其相应目标对象(主调函数操作。...(3)使用指针作为函数参数虽然也能达到与使用引用效果,但是,在被调函数同样要给形参分配存储单元,且需要重复使用"*指针变量名"形式进行运算,这很容易产生错误且程序阅读性较差;另一方面,主调函数调用点处...如【例5】2种情况出现编译错误。 (2)不能返回函数内部new分配内存引用。这条可以参照Effective C++[1]Item 31。...如果A类定义有虚函数,并且B类重写了这个虚函数,就可以通过Ref产生多态效果。...引用总结 (1引用使用,单纯给某个变量取个别名是毫无意义,引用目的主要用于函数参数传递,解决大块数据或对象传递效率和空间不如意问题。

    54320
    领券