热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

多益网络2019秋招笔试题

1、哈希散列值的计算平均查找长度哈希表的构造方法:(1)、数字分析法:事先知道关键字的集合,且每个关键字的位数

1、哈希散列值的计算平均查找长度

        哈希表的构造方法:

            (1)、数字分析法:事先知道关键字的集合,且每个关键字的位数比哈希表的地址码位数多时,可以从关键字中选出分布比较均匀的若干位,构成哈希地址。

            (2)、平方取中法:当无法确定关键字中哪几位分布比较均匀时,可以先求出关键字的平方值的中间几位作为哈希地址

            (3)、分段叠加法:按哈希表的地址位数将关键字分成位数相等的几部分(最后一部分较短),然后将这几部分相加,舍弃最高位后的结果就是该关键字的哈希地址。

            (4)、除留余数法:假设哈希表长为 m,p为小于等于 m 的 最大数数,则哈希 函数为 H(k) = k%p

            (5)、伪随机数为:采用一个伪随机函数作为哈希函数,即 H(key) = random(key)

         哈希表处理冲突的方法:

            (1)、开放定址法

            (2)、再哈希法

            (3)、链地址法   

            (4)、建立公共溢出区

          哈希表的性能分析:

                哈希法中影响关键字比较次数的因素有三个:哈希函数,处理冲突的方法,哈希表的装填因子。装填因子 a 的定义如下:         a  = 哈希表中元素的个数 / 哈希表的长度            a 可描述哈希表的装满程度。a 越小,发生冲突的可能性越小; a 越大 ,发生冲突的可能性越大。

2、堆的排序算法

3、后缀表达式

         前缀表达式、中缀表达式、后缀表达式都是四则运算的表达方式,用以四则运算表达式求值,即数学表达式的求值。

         前缀表达式:前缀表达式又称波兰式,前缀表达式的运算符位于操作数之前。比如:- × + 3 4 5 6。前缀表达式求值:从右至左扫描表达式,遇到数字时,将数字压入堆栈,遇到运算符时,弹出栈顶的两个数,用运算符对它们做相应的计算(栈顶元素 op 次顶元素),并将结果入栈;重复上述过程直到表达式最左端,最后运算得出的值即为表达式的结果

         中缀比表达式:中缀表达式就是常见的运算表达式,如(3+4)×5-6。

         后缀表达式:后缀表达式又称逆波兰表达式,与前缀表达式相似,只是运算符位于操作数之后。比如: 3 4 + 5 × 6 - 。
         具体使用方法,参考博客:https://www.cnblogs.com/Hslim/p/5008460.html

4、哈夫曼编码

     参考博客:https://blog.csdn.net/dongfei2033/article/details/80657360

5、二叉树的结点计算问题及性质

        性质1 : 二叉树的第 i 层上至多有 2^(i-1) 个结点 (i>=1)

        性质2 :  深度为 k 的二叉树至多有 2^k -1 个结点( k>=1)

        性质3 :  对任意的一颗二叉树 T ,若叶子结点数为 n0,而其度数为 2 的结点数为 n2,则 n0 = n2+1

        性质4 :  具有 n 个结点的完全二叉树的深度 [log2n]+1

        性质 5&#xff1a;  如果有一颗有n个节点的完全二叉树的节点按层次序编号&#xff0c;对任一层的节点i&#xff08;1<&#61;i<&#61;n&#xff09;有

                        (1).如果i&#61;1&#xff0c;则节点是二叉树的根&#xff0c;无双亲&#xff0c;如果i>1&#xff0c;则其双亲节点为[i/2]&#xff0c;向下取整

                        (2).如果2i>n那么节点i没有左孩子&#xff0c;否则其左孩子为2i

                        (3).如果2i&#43;1>n那么节点没有右孩子&#xff0c;否则右孩子为2i&#43;1

6、关系型数据库的构成

       关系型数据是指以关系数学模型来表示的数据&#xff0c;关系数学模型中以二维表的形式来描述数据。关系型数据库是存储在计算机上的、可共享的、有组织的关系型数据的集合。 关系模型由关系数据结构&#xff0c;关系操作集合、关系完整性约束三部分组成。

7、文件逻辑记录和文件物理记录

    记录是文件存取操作的基本单位。逻辑记录&#xff1a;是按用户观点的基本存取单位。物理记录&#xff1a;是按外存设备观点的基本存取单位。通常逻辑记录和物理记录之间存在三种关系&#xff1a;(1)一个物理记录存放一个逻辑记录&#xff1b; (2)一个物理记录包含多个逻辑记录&#xff1b; (3)多个物理记录表示一个逻辑记录。

8、sql 的索引&#xff0c;主键&#xff0c;唯一索引&#xff0c;联合索引的区别&#xff0c;对数据库有什么影响

          &#xff08;1&#xff09;索引是一种特殊的文件&#xff0c;它们包含数据表里的所有记录的引用指针。索引的遵照原则&#xff1a;

                    (a). 最左侧原则&#xff1a;表的最左侧一列&#xff0c;往往数据不会发生改变&#xff0c;不影响其他列的数据

                    (b).命名短小原则&#xff1a;索引命名过长会使索引文件变大&#xff0c;损耗内存。

            (2). 普通索引&#xff08;由关键字 KEY或 INDEX 定义得到的索引&#xff09;&#xff1a;加快数据的查询速度

            (3). 唯一索引&#xff08;由关键字 UNIQUE 把它定义为唯一索引&#xff09;&#xff1a;保证数据的唯一性

            (4). 主键&#xff1a;一种特殊的唯一索引&#xff0c;一张表中只能定义一个主键索引&#xff0c;用来标识唯一一条数据&#xff0c;用 PRIMARY KEY 创建

            (5). 联合索引&#xff1a;索引可以覆盖多个数据列&#xff0c;如像 INDEX 索引就是联合索引

            索引可以极大的提高查询访问速度&#xff0c;但是会降低插入&#xff0c;删除&#xff0c;更新表的速度&#xff0c;应为在执行写的操作的时候还要操作索引文件。

9、TCP 传输的时候怎么保证传输的可靠性

            参考我的往期博客&#xff1a; 

                    https://blog.csdn.net/qq_35396127/article/details/80847189

10、如何确定UDP传输中是数据包是否被接收方正确接收。
        可以在每个数据包中插入一个唯一的ID&#xff0c;比如timestamp或者递增的int。 发送方在发送数据时将此ID和发送时间记录在本地。 接收方在收到数据后将ID再发给发送方作为回应 发送方如果收到回应&#xff0c;则知道接收方已经收到相应的数据包&#xff1b;如果在指定时间内没有收到回应&#xff0c;则数据包可能丢失&#xff0c;需要重复上面的过程重新发送一次&#xff0c;直到确定对方收到。

11、数据库的安全性&#xff1a;指保护数据库&#xff0c;防止不合法的使用造成的数据泄露、更改或破坏。

SQL Server 2000 的安全性机制由四层构成
第一层&#xff1a;操作系统的登录
第二层&#xff08;服务器安全管理&#xff09;&#xff1a;SQL Server的登录————特殊账户sa
第三层&#xff08;数据库安全管理&#xff09;&#xff1a;数据库的访问权————成为数据库用户
第四层&#xff08;数据库对象安全管理&#xff09;&#xff1a;数据库对象&#xff08;表、视图等&#xff09;的访问权———数据库用户获得角色

12、事务隔离级别是由谁实现的&#xff1f;&#xff08;数据库系统&#xff09;
         在数据库操作中&#xff0c;为了有效保证并发读取数据的正确性&#xff0c;提出的事务隔离级别&#xff1b;为了解决更新丢失&#xff0c;脏读&#xff0c;不可重读&#xff08;包括虚读和幻读&#xff09;等问题在标准SQL规范中&#xff0c;定义了4个事务隔离级别&#xff0c;分别为未授权读取&#xff0c;也称为读未提交&#xff08;read uncommitted&#xff09;&#xff1b;授权读取&#xff0c;也称为读提交&#xff08;read committed&#xff09;&#xff1b;可重复读取&#xff08;repeatable read&#xff09;&#xff1b;序列化&#xff08;serializable&#xff09;.

编程题&#xff1a;

幸福的数字是由以下过程定义的数字&#xff1a;从任何正整数开始&#xff0c;将数字替换为数字的平方和&#xff0c;并重复该过程&#xff0c;直到数字等于1&#xff08;将保留在哪里&#xff09;&#xff0c;或者循环 一个不包括在内的循环的循环中&#xff0c;这个过程以1结尾的数字是快乐的数字。例如19是幸运数字 给定一个数&#xff0c;计算是不是幸运数。

解题思路&#xff1a;

/*
while 该位上的数不为0{1.计算给定数的每位上的数2.计算其每位数上的平方和
}
如果平方和不为1&#xff0c;返回重新计算该平方和的各个位置上数的新的平方和&#xff0c;1000次后还不为1&#xff0c;可能不是幸运数&#xff1b;
如果平方和为1&#xff0c;return true
*/public class test
{public static void main(String[] args){int input &#61; 101;System.out.println(isHappy(input));}static boolean isHappy(int n){int cnt &#61; 0, k &#61; n;while (k !&#61; 1 && cnt <1000){int tmp &#61; 0;while (k !&#61; 0){tmp &#43;&#61; (k % 10) * (k % 10);k /&#61; 10;}k &#61; tmp;cnt&#43;&#43;;}return k &#61;&#61; 1;}
}

转载地址&#xff1a;https://blog.csdn.net/qq_35396127/article/details/80820502


推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • Java 中的 BigDecimal pow()方法,示例 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • Java 中 Writer flush()方法,示例 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文总结了汇编语言中第五至第八章的关键知识点,涵盖间接寻址、指令格式、安全编程空间、逻辑运算指令及数据重复定义等内容。通过详细解析这些内容,帮助读者更好地理解和应用汇编语言的高级特性。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • FinOps 与 Serverless 的结合:破解云成本难题
    本文探讨了如何通过 FinOps 实践优化 Serverless 应用的成本管理,提出了首个 Serverless 函数总成本估计模型,并分享了多种有效的成本优化策略。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 使用C#开发SQL Server存储过程的指南
    本文介绍如何利用C#在SQL Server中创建存储过程,涵盖背景、步骤和应用场景,旨在帮助开发者更好地理解和应用这一技术。 ... [详细]
  • Codeforces Round #566 (Div. 2) A~F个人题解
    Dashboard-CodeforcesRound#566(Div.2)-CodeforcesA.FillingShapes题意:给你一个的表格,你 ... [详细]
author-avatar
让爱自由2009
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有