javascript剑指offer编程练习#5

第三十一题

题目描述
求出1~13的整数中1出现的次数,并算出100~1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1、10、11、12、13因此共出现6次,但是对于后面问题他就没辙了。ACMer希望你们帮帮他,并把问题更加普遍化,可以很快的求出任意非负整数区间中1出现的次数(从1 到 n 中1出现的次数)。

function NumberOf1Between1AndN_Solution(n)
{
    // write code here
    if(n<0){
        return 0
    }
    let arr=[]
    while(n){
        arr.push(n)
        n--;
    }
    let reg=/[^1]+/g//匹配所有不是1的字符
    return arr.join('').replace(reg,'').length
}

利用正则表达式,巧妙的解决

第三十二题

题目描述
输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。

function PrintMinNumber(numbers)
{
    // write code here
    if(!numbers||numbers.length===0){
        return ''
    }
    numbers.sort(compare)
    let result=''
    numbers.forEach(item=>{
        result+=item
    })
    return result
}
function compare(a,b){
    let str1=a+''+b
    let str2=b+''+a
    if(parseInt(str1)>parseInt(str2)){
            return 1
     }else{
            return -1
     }
    return 1
    
}

此题的思路利用sort()方法是对numbers进行排序,而sort()的排序规则为:

  • 若ab > ba 则 a > b,
  • 若ab < ba 则 a < b,
  • 若ab = ba 则 a = b;
    比如 “3” , “31”, “331” > “313”,所以"3">“31”

第三十三题

题目描述
把只包含质因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含质因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。

function GetUglyNumber_Solution(index)
{
    // write code here
    if(index===0){
        return 0
    }
    let f2=0,f3=0,f5=0
    let arr=[1]
    for(let i=1;i<index;i++){
        arr[i]=Math.min(arr[f2]*2,arr[f3]*3,arr[f5]*5)
        if(arr[i]===arr[f2]*2)f2++
        if(arr[i]===arr[f3]*3)f3++
        if(arr[i]===arr[f5]*5)f5++
    }
    return arr[index-1]
}

丑数的集合为
第一个元素为1,f2,f3,f5分别记录是第几个元素,每个元素*2,*3,*5均为丑数元素,从小到大排列即可

第三十四题

题目描述
在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写).

function FirstNotRepeatingChar(str)
{
    // write code here
    if(!str||str.length===0){
        return -1
    }
    let arr=str.split('')
    for(let i=0;i<arr.length;i++){
        if(arr.indexOf(arr[i])===arr.lastIndexOf(arr[i])){
            return i
            break
        }
   }
    return -1
    
}

第三十五题

题目描述
在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数P。并将P对1000000007取模的结果输出。 即输出P%1000000007
输入描述:
题目保证输入的数组中没有的相同的数字

数据范围:

对于%50的数据,size<=10^4

对于%75的数据,size<=10^5

对于%100的数据,size<=2*10^5

示例1
输入
1,2,3,4,5,6,7,0
输出
7

第三十六题

题目描述
输入两个链表,找出它们的第一个公共结点。

/*function ListNode(x){
    this.val = x;
    this.next = null;
}*/
function FindFirstCommonNode(pHead1, pHead2)
{
    // write code here
    let p1=pHead1
    let p2=pHead2
    while(p1!=p2){
        p1= (p1===null? pHead2:p1.next)
        p2= (p2===null? pHead1:p2.next)
    }
    return p2
}

第三十七题

题目描述
统计一个数字在排序数组中出现的次数。

function GetNumberOfK(data, k)
{
    // write code here
    return data.reduce((a,c)=>{
        return c===k?a+1:a
    },0)
}

第三十八题

题目描述
输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度。

/* function TreeNode(x) {
    this.val = x;
    this.left = null;
    this.right = null;
} */
function TreeDepth(pRoot)
{
    // write code here
    if(!pRoot){
        return 0
    }
    let left=TreeDepth(pRoot.left)
    let right=TreeDepth(pRoot.right)
    
    return Math.max(left,right)+1
}

第三十九题

题目描述
输入一棵二叉树,判断该二叉树是否是平衡二叉树。

/* function TreeNode(x) {
    this.val = x;
    this.left = null;
    this.right = null;
} */
function IsBalanced_Solution(pRoot)
{
    // write code here
    if(!pRoot){
        return true
    }
    let left=TreeDepth(pRoot.left)
    let right=TreeDepth(pRoot.right)
    if(Math.abs(left-right)>1){
        return false
    }
    return IsBalanced_Solution(pRoot.left)&&IsBalanced_Solution(pRoot.right)
}
function TreeDepth(pRoot)
{
    // write code here
    if(!pRoot){
        return 0
    }
    let left=TreeDepth(pRoot.left)
    let right=TreeDepth(pRoot.right)
    
    return Math.max(left,right)+1
}

平衡二叉搜索树(Self-balancing binary search tree)又被称为AVL树(有别于AVL算法),且具有以下性质:它是一 棵空树或它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是一棵平衡二叉树。可利用上一题的方法来递归解决该问题

第四十题

题目描述
一个整型数组里除了两个数字之外,其他的数字都出现了偶数次。请写程序找出这两个只出现一次的数字。

function FindNumsAppearOnce(array)
{
    // write code here
    // return list, 比如[a,b],其中ab是出现一次的两个数字
    if(!array||array.length<2){
        return []
    }
    let result=[] 
    for(let i=0;i<array.length;i++){
        if(array.indexOf(array[i])===array.lastIndexOf(array[i])){
            result.push(array[i])
        }
    }
    return result
}

第四十一题

题目描述
小明很喜欢数学,有一天他在做数学作业时,要求计算出9~16的和,他马上就写出了正确答案是100。但是他并不满足于此,他在想究竟有多少种连续的正数序列的和为100(至少包括两个数)。没多久,他就得到另一组连续正数和为100的序列:18,19,20,21,22。现在把问题交给你,你能不能也很快的找出所有和为S的连续正数序列? Good Luck!
输出描述:
输出所有和为S的连续正数序列。序列内按照从小至大的顺序,序列间按照开始数字从小到大的顺序

function FindContinuousSequence(sum)
{
    // write code here
    if(!sum||sum.length<2){
        return []
    }
    let p1=1,p2=2
    let result=[]
    while(p2>p1){
        let cur=(p2+p1)*(p2-p1+1)/2
        if(cur<sum){
            p2++
        }
        if(cur===sum){
            let res=[]
            for(let i=p1;i<=p2;i++){
               res.push(i)
            }
            result.push(res)
            p1++
        }
        if(cur>sum){
            p1++
        }
    }
    return result
}

双指针思路,如果过指针之间的值小于sum,大指针+1,如果大于sum,小指针+1

第四十二题

题目描述
输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。
输出描述:
对应每个测试案例,输出两个数,小的先输出。

function FindNumbersWithSum(array, sum)
{
    // write code here
    if(!array||array.length<2){
        return []
    }
    let result=[]
    let start = 0, 
        end = array.length-1; 
    while(start < end){ 
        if(array[start]+array[end] < sum){ 
            start++; 
        }else if(array[start]+array[end] > sum){ 
            end--; 
        }else{ 
            return [array[start],array[end]]; 
        } 
    }
    return result
    
}

第四十三题

题目描述
汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它!

function LeftRotateString(str, n)
{
    // write code here
    if(!str||str.length===0){
        return ''
    }
    n=n%str.length
    return str.slice(n)+str.slice(0,n)
}

第四十四题

题目描述
牛客最近来了一个新员工Fish,每天早晨总是会拿着一本英文杂志,写些句子在本子上。同事Cat对Fish写的内容颇感兴趣,有一天他向Fish借来翻看,但却读不懂它的意思。例如,“student. a am I”。后来才意识到,这家伙原来把句子单词的顺序翻转了,正确的句子应该是“I am a student.”。Cat对一一的翻转这些单词顺序可不在行,你能帮助他么?

function ReverseSentence(str)
{
    // write code here
    return str.split(' ').reverse().join(' ')
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值