自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(19)
  • 收藏
  • 关注

原创 【剑指offer-第二版】部分题目与解答【C++版本】

20180612求职在即,《剑指offer》作为大家都推荐的一本应试宝典,确实也有刷一刷的必要。很多题目都比较经典,也涵盖了大多数的算法和数据结构。把自己刷题的过程做一个总结,权当是一个笔记。 我自己使用的《剑指offer》第二版,所以题目顺序也按照第二版书上的顺序。 如果是牛客网上面《剑指offer》专题上面有的题目,给出的代码都能够AC通过,但如果是没有的题目,就只做了几个简单...

2018-06-12 18:39:11 7400 1

原创 【剑指offer】面试题45:把数组排成最小的数【C++版本】

题目:输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如:输入数组{3,32,321},则打印出这3个数字能排成的最小数字321323解题思路:1.制定一种新的排序规则,数组根据这个规则排序之后能够排成一个最小的数字。 2.要制定新的排序规则,就必须制定新的比较规则,即通过比较m和n,来确定哪一个应该排在前面(即哪一个更“小”)...

2018-06-09 16:33:57 1312

转载 hadoop常用命令

hadoop常用命令: hadoop fs 查看Hadoop HDFS支持的所有命令 hadoop fs –ls 列出目录及文件信息 hadoop fs –lsr 循环列出目录、子目录及文件信息 hadoop fs –put test.txt /user/sunlightcs 将本地文件系统的test.txt复制到HDFS文件系统的/user/sunlightcs目...

2018-06-15 14:48:18 146

转载 Hadoop,MapReduce,YARN和Spark的区别与联系

 (1) Hadoop 1.0   第一代Hadoop,由分布式存储系统HDFS和分布式计算框架MapReduce组成,其中,HDFS由一个NameNode和多个DataNode组成,MapReduce由一个JobTracker和多个TaskTracker组成,对应Hadoop版本为Hadoop 1.x和0.21.X,0.22.x。   (2) Hadoop 2.0   第二代Hadoop...

2018-06-14 20:02:35 838

原创 【剑指offer】面试题16:数值的整数次方【C++版本】

题目:实现函数double Power(double base,int exponent),求base的exponent次方。不需要考虑大数问题解题思路:1.这个题目看起来很简单,但其实考察的是考虑到边界问题和错误输入 2.应该分别分析底数和指数大于0、等于0、小于0的情况 两种最特殊的情况: 1.当底数为0而指数为负数的时候,是错误输入。 2.当指数为负数的...

2018-06-12 20:58:33 456

原创 【剑指offer】面试题15:二进制中1的个数【C++版本】

题目:请实现一个函数,输入是一个整数,输出该数二进制表示中1的个数。例如,把9表示成二进制是1001,有2位是1。因此,如果输入9,则该函数输出为2。解题思路:1.不对数据进行移位,而是移位和数据进行与操作的1。因为移位数据可能会因为符号位而造成死循环 2.O(1)的解法。使用公式n = (n-1)&n;n =&amp

2018-06-12 19:26:29 847 1

原创 【剑指offer】面试题14:剪绳子【C++版本】

题目:给一段长度为n的绳子,把绳子剪成m段(m,n都是整数且n>1,m>1,即至少要剪一次),问每段绳子长度的乘积最大是多少?求解思路:1.使用动态规划求解: 2.确定子问题:例如绳子的长度为8,那么可以剪成1,7两段,那么此时又要求解长度为7的绳子怎么剪最好。依次类推。 3.确定转移方程,设方程f(i) f(i)f(i)表示长度为i ii的绳子剪成...

2018-06-12 17:24:20 1981

原创 【剑指offer】面试题50:(字符流中)第一个只出现一次的字符【C++版本】

题目:字符串中第一个只出现一次的字符。在字符串中找出第一个只出现一次的字符。如输入"abaccdeff" "abaccdeff""abaccdeff",则输出 ′ b&a

2018-06-12 15:50:50 1117

原创 【剑指offer】面试题49:丑数【C++版本】

题目:我们把只包含因子2,3,5的数称作丑数。求按从小到大的顺序的第1500个丑数。例如,6,8都是丑数,但14不是丑数,因为它包含因子7。习惯上我们把1当作第一个丑数。解题思路:1.首先要理解丑数的概念。换个角度理解,因为丑数只能被2,3,5整除。也就是说,如果一个数能被2整除,就继续除以2,能被3整除,就继续除以3,能被5整除,就继续除以5。这样到最后得到的结果是1,那么这个数...

2018-06-12 11:34:48 1153

原创 【剑指offer】面试题48:最长不含重复字符的子字符串【C++版本】

题目:请从字符串中找出一个最长的不包含重复字符的子字符串,计算该最长子字符串的长度。假设字符串中只包含 ′ a ′  ′a′'a'~ ′&amp

2018-06-11 21:24:59 2497 1

原创 【剑指offer】面试题47:礼物的最大价值【C++版本】

题目:在一个m×n m×nm×n的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值(价值大于0)。你可以从棋盘的左上角开始拿格子里的礼物,并每次向右或者向下移动一格,直到到达棋盘的右下角。给定一个棋盘及其上面的礼物,请计算你最多能够拿到多少价值的礼物。解题思路:1.使用动态规划求解。 2.定义一个函数f(i,j) f(i,j)f(i,j)表示达到坐标(i,j)&...

2018-06-11 19:43:23 1447

原创 【剑指offer】面试题46:把数字翻译成字符串【C++版本】

题目:给定一个数字,我们按照如下规则把它翻译为字符串:0翻译成“a”,1翻译成“b”,……,11翻译成“l”(小写的“L”),……,25翻译成“z”。一个数字可能有多个翻译。例如:12258有5种不同的翻译,分别是“bccfi” 、“bwfi” 、“bczi” 、“mcfi” 和 “mzi”。请编程实现一个函数,用来计算一个数字有多少种不同的翻译方法。解题思路:1.使用动态规划的思...

2018-06-11 16:46:10 936

原创 【剑指offer】面试题44:数字序列中某一位的数字【C++版本】

20180609题目:数字以0123456789101112131415…的格式序列化到一个字符序列中。在这个序列中,第5位(从0开始计数)是5,第13位是1,第19位是4,等等。请写一个函数,求任意第n位对应的数字。解题思路:1.从位数为1开始统计不同的位数的数字所占的总位数,如0~9一共占10位,10~99一共占180位…并进行累加,一旦累加的和超过给定的位数,...

2018-06-09 15:20:19 931

原创 【剑指offer】面试题13:机器人的运动范围【C++版本】

20180608题目:地上有一个m行n列的格子,一个机器人从(0,0)开始移动,它每次可以向上、下、左、右移动一格,但是不能进入行坐标和列坐标的数位之和大于k的格子。例如,当k等于18时,机器人能够进入方格(35,37),因为3+7+3+5 = 18。但是它不能进入方格(35,38),因为3+5+3+8 = 19 > 18。请问该机器人能够进入多少个格子?解题思路...

2018-06-08 22:03:40 1046

原创 【剑指offer】面试题43:1~n整数中1出现的次数【C++版本】

20180608题目:输入一个整数n,求1~n这n个整数的十进制表示中1出现的次数。例如:输入12,1~12这些整数中包含1的数字有1、10、11和12,1一共出现了5次注意:1.求解的是1出现的次数,一个数字里面1可能出现多次,比如111。而不是包含1的数字出现的次数 2.不能这样分段,比如把21345分成1~20000,20001~21345两段,这样分段更加不好...

2018-06-08 21:10:13 791

原创 【剑指offer】面试题12:矩阵中的路径【C++版本】

20180602题目:设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。路径可以从矩阵任意一格开始,每一步可以在矩阵中向上、下、左、右移动一格。如果一条路径经过了矩阵中的某一格,那么该路径不能再次进入该格子。解题思路:可以用回溯法来解决的典型问题。 回溯法: 回溯法可以看成蛮力法的升级版,它从解决问题的每一步的所有可能选项里系统...

2018-06-02 12:50:16 1404

原创 【剑指offer】面试题42:连续子数组的最大和【C++版本】

20180602题目:输入一个整型数组,数组里面有正数也有负数。数组中的一个或连续多个整数组成自一个子数组,求所有子数组的和的最大值。要求时间复杂度为O(n)解题思路:解法一:举例分析数组的规律例如输入的数组为{1,-2,3,10,-4,7,2,-5},则计算步骤如下: 1.初始化和 sum sum\ sum 为0,最大子数组和&nbs...

2018-06-02 10:47:15 638

原创 【剑指offer】面试题11:旋转数组的最小数字【C++版本】

20180601题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素。题目解析:1.旋转之后的数组实际上可以划分为两个排序的子数组,前面子数组的元素都大于或者等于后面子数组的元素,最小的元素恰好是两个子数组的分界线 2.找中位数 mid  mid\ mid ,如果...

2018-06-01 16:06:24 548

原创 【剑指offer】面试题41:数据流中的中位数【C++版本】

20180601题目:如何得到一个数据流中的中位数?如果从数据流中读取奇数个数值,那么中位数就是所有数值排序之后位于中间的数值。如果从数据流中读出偶数个数值,那么中位数就是所有数值排序后中间两个数的平均数解题思路:1.本来使用一个AVL树来实现是最佳的,但是各种语言的函数库都还没有现成的AVL树的实现,所以选择使用两个堆来完成。使用一个最大堆实现中位数左边的数据容器...

2018-06-01 14:50:35 1005 1

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除