在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写).
哈希表
1 | class Solution { |
在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写).
哈希表
1 | class Solution { |
把只包含质因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含质因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。
类质数筛法
1 | class Solution { |
输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。
1 | struct::bool operator()(const string a, const string b) const |
1 | class Solution { |
求出任意非负整数区间中1出现的次数(从1 到 n 中1出现的次数)。
分段,按位
1 | class Solution { |
计算连续子向量的最大和,向量中包含负数。例如:{6,-3,-2,7,-15,1,2,2},连续子向量的最大和为8(从第0个开始,到第3个为止)。给一个数组,返回它的最大连续子序列的和,你会不会被他忽悠住?(子向量的长度至少是1)
连续累加,小于0了则归零。
1 | class Solution { |
输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。
partition、堆、红黑树
1 | class Solution { |
数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。如果不存在则输出0。
该数存在,等价于,删去该数的个数恰为子数组长度一半的子数组,将其余部分为新数组,则该数在新数组中的个数依然过半,即
freq>21len⇔freq−21subLen>21(len−subLen)
1 | class Solution { |
输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。
排列树,依次交换。字符重复则不交换。
1 | class Solution { |
输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。
左子树即链表的左边,右子树同理。多返回值以避免冗余的迭代。
1 | /* |
输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点),返回结果为复制后复杂链表的head。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空)
先复制不复杂(无支链)的链表,将新节点连接在旧节点后,再复制新节点的支链,最后拆分2个链表。
1 | /* |