题目描述 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 保证base和exponent不同时为0   问题分析 计算一个浮点数的整数次方,主要考察的是对输入数据的完整性的预估能力.针对此问题,输入数据可能存在以下情况: 1.底数不为0,指数都为整数 2.底数不为0,指数都为负数 3.底数为0,指数为负数(出现零除情况) 4.底数为0,指数为正数(给定特殊值0或1) 代码实现的逻辑并不复杂,主要是需要考虑到所有可能存在的输入情况,同…
题目:实现函数double Power(double base,int exponent),求base的 exponent次方.不得使用库函数,同时不需要考虑大数的问题. 这道题看似很简单: 然而需要考虑的方面到不少: 1.如何处理指数为负数,将负数当成正数处理 对结果求倒 2.当指数为负数的时候并且底数为0的时候如何处理 3.当指数为0底数为0的情况 这里我们这样考虑,把底数为0的所有输入处理为无效输入,返回0 代码实现如下: #include <iostream> using namesp…
剑指 Offer 43. 1-n 整数中 1 出现的次数 Offer_43 题目描述 题解分析 java代码 package com.walegarrett.offer; /** * @Author WaleGarrett * @Date 2021/2/8 9:29 */ /** * 题目详情: * 输入一个整数 n ,求1-n这n个整数的十进制表示中1出现的次数. * 例如,输入12,1-12这些整数中包含1 的数字有1.10.11和12,1一共出现了5次. */ public class O…
剑指 Offer 20. 表示数值的字符串 Offer 20 常规解法: 题目解题思路:需要注意几种情况: 输入的字符串前后可能有任意多个空格,这是合法的. 正负号: (1)正负号只能出现一次. (2)正负号后面一个字符必须是数字或者小数点. (3)字符串中最多有两个正负号(正常情况下最多只有一个,但是这里有指数E的情况,其前后可以加正负号). e或者E: (1) 指数符号最多出现一次. (2) 前一个字符必须是数字或者小数点,如果是小数点,则小数点不能出现在第一个字符的位置. (3) 后一个字…
该题目来源于牛客网<剑指offer>专题. 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100","5e2","-123","3.1416"和"-1E-16"都表示数值.但是"12e","1a3.14","1.2.3","±5"和"12e+4.3"都不是. Go语言…
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集   题目 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串“+100”.“5e2”.“-123”.“3.1416”及“-1E-16”都表示数值,但“12e”.“1a3.14”.“1.2.3”.“+-5”及“12e+5.4”都不是. 思路 刚开始的思路是从头到尾遍历,对遇到的不同情况进行分析,但很容易出错.因此采用<剑指OFFER>一书的方法:将数字…
题目描述 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 题目分析 这道题用传统的方法也可以做,只不过效率太低,这里我们用到快速幂的方法.不懂可以百度搜快速幂,原理如下: 也就是说我们要算a的11次方,我们只需要算a的1次方,a的2次方,a的8次方,也就是说我们结果需要算的是这个指数对应的二进制数上有1的位, 比如1011,所以          好了,此外再说一句,对1进行按位与,可以判断二进制数最右边的位数是否为1,因此也可以判…
题目描述 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 题目地址 https://www.nowcoder.com/practice/1a834e5e3e1a4b7ba251417554e07c00?tpId=13&tqId=11165&tPage=1&rp=3&ru=%2Fta%2Fcoding-interviews&qru=%2Fta%2Fcoding-interviews%2Fquestion-…
  题目描述:   给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方.   解题思路:   本题看似比较简单,是一个简单的指数运算,但需要完整的考虑到所有情况.首先,对于底数,如果底数为0,则0的任何次方都是0,可以直接返回0.关键在于指数,指数可能有三种情况,有可能是正数.0.负数.对于指数是0的情况,任何数的0次方为1.对于指数是负数的情况,可以将其转化为绝对值计算,求出结果之后再求倒数.   在计算n次方的时候,为了方便,我们根据…
[思路1]递归 class Solution { public: double Power(double base, int exponent) { ){ /base; exponent = -exponent; } ){ ; }else{ ); } } }; [思路2]快速幂 class Solution { public: double Power(double base, int exponent) { long long p = abs((long long)exponent); dou…
   字符和数字加减就是字符的ASCII码和数字直接加减. 方法一: 1)在字符串操作中给一个整形数字加(字符0)就是把它转化为字符,当然给一个字符减去(字符0)就可以把它转化为数字了:如果确实是最后一位字符那仫就把该数字加1( 需要注意的是我们每次都是从最后一个字符开始加起)到这里我们就不得不考虑加法的进位了,只有当字符对应的数字加到10或者比10大时我们需要进位,否则就直接将该数字转化为字符存储到对应字符的位置中去: 在字符所转化的数字进位中不得不考虑的就是如果此时已经是第一个字符了那仫还需…
题目描述 将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数. 数值为0或者字符串不是一个合法的数值则返回0 输入描述: 输入一个字符串,包括数字字母符号,可以为空 输出描述: 如果是合法的数值表达则返回该数字,否则返回0 输入例子: +2147483647 1a33 输出例子: 2147483647 0 思路: 写了个判断是不是数字字符串的函数. 不是数字字符串直接返回0,是数字字符串,判断首字母是不是符号,是从第二个位置开始计数. AC代码: class Solution { p…
题目描述 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100","5e2","-123","3.1416"和"-1E-16"都表示数值. 但是"12e","1a3.14","1.2.3","+-5"和"12e+4.3"都不是. 题目地址 https://www.nowcoder…
请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100","5e2","-123","3.1416"和"-1E-16"都表示数值. 但是"12e","1a3.14","1.2.3","+-5"和"12e+4.3"都不是. 题目是要判断一个表达式是否满足预设规则.其实就是正则匹配.正…
题目描述: 将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数. 数值为0或者字符串不是一个合法的数值则返回0   输入描述: 输入一个字符串,包括数字字母符号,可以为空 输出描述: 如果是合法的数值表达则返回该数字,否则返回0   示例1 输入 +2147483647 1a33 输出 2147483647 0 分析: 只可能在最开始一位出现符号,所以我们特殊判断第一位,之后都得是数字字母,不然不合法. 代码: class Solution { public: int StrToIn…
题目描述 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100","5e2","-123","3.1416"和"-1E-16"都表示数值. 但是"12e","1a3.14","1.2.3","+-5"和"12e+4.3"都不是 [思路]本题要注意考虑各种情况,下面代码有详解 cl…
题目描述请你写一个函数StrToInt,实现把字符串转换成整数这个功能.当然,不能使用atoi或者其他类似的库函数. 示例 1:输入: " -42"输出: -42解释: 第一个非空白字符为 '-', 它是一个负号. 示例 2:输入: "4193 with words"输出: 4193解释: 转换截止于数字 '3' ,因为它的下一个字符不为数字. 示例 3:输入: "words and 987"输出: 0解释: 第一个非空字符是 'w', 但它不是…
题目描述 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100","5e2","-123","3.1416"和"-1E-16"都表示数值. 但是"12e","1a3.14","1.2.3","+-5"和"12e+4.3"都不是. 挑出“不合规则”的更容易一些. class Sol…
题目描述: 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100","5e2","-123","3.1416"和"-1E-16"都表示数值. 但是"12e","1a3.14","1.2.3","+-5"和"12e+4.3"都不是. 思路分析: 1. 第一种思路,是对于这种数值表示…
题目描述 求出1~13的整数中1出现的次数,并算出100~1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1.10.11.12.13因此共出现6次,但是对于后面问题他就没辙了.ACMer希望你们帮帮他,并把问题更加普遍化,可以很快的求出任意非负整数区间中1出现的次数(从1 到 n 中1出现的次数). 思路 像类似这样的问题,我们可以通过归纳总结来获取相关的东西. 首先可以先分类: 个位 我们知道在个位数上,1会每隔10出现一次,例如1.11.21等等,我们发现以10为一个…
题目描述 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100","5e2","-123","3.1416"和"-1E-16"都表示数值. 但是"12e","1a3.14","1.2.3","+-5"和"12e+4.3"都不是.   题解: 表示数值的字符串遵循模式A[[B]][…
题目描述 将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数. 数值为0或者字符串不是一个合法的数值则返回0 输入描述: 输入一个字符串,包括数字字母符号,可以为空 输出描述: 如果是合法的数值表达则返回该数字,否则返回0 示例1 输入 +2147483647 1a33 输出 2147483647 0 思路:字符串转化为整数的方法num = num * 10 + str[i] - '0':特殊情况:1.输入字符串为NULL: 2.输入字符串只有+/-: 3.转化的数字大于最大值或小于…
题目信息 时间: 2019-07-01 题目链接:Leetcode tag: 整除 取余 规律 递归 难易程度:中等 题目描述: 输入一个整数 n ,求1-n这n个整数的十进制表示中1出现的次数. 例如,输入12,1-12这些整数中包含1 的数字有1.10.11和12,1一共出现了5次. 示例1: 输入:n = 12 输出:5 示例2: 输入:n = 13 输出:6 提示 1. 1 <= n < 2^31 解题思路 本题难点 数字 n 是个 x 位数,记 n 的第 i 位为 n i ,则可将…
题目描述 输入一个整数 n ,求1-n这n个整数的十进制表示中1出现的次数. 例如,输入12,1-12这些整数中包含1 的数字有1.10.11和12,1一共出现了5次. 示例 1: 输入:n = 12 输出:5 示例 2: 输入:n = 13 输出:6 限制: 1 <= n < 2^31 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/1nzheng-shu-zhong-1chu-xian-de-ci-shu-lcof 代码实现 clas…
面试12题: 题目:矩阵中的路径 题:请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径.路径可以从矩阵中的任意一个格子开始,每一步可以在矩阵中向左,向右,向上,向下移动一个格子.如果一条路径经过了矩阵中的某一个格子,则该路径不能再进入该格子. 例如 a b c e s f c s a d e e 矩阵中包含一条字符串"bcced"的路径,但是矩阵中不包含"abcb"路径,因为字符串的第一个字符b占据了矩阵中的第一行第二个格子之后,路径不能再…
输入一个整数,输出该数二进制表示中1的个数.其中负数用补码表示. public class Solution { public int NumberOf1(int n) { String str = Integer.toBinaryString(n); char [] c = str.toCharArray(); int t = 0; for(int i = 0; i < c.length; i++){ if(c[i] == '1'){ t++; } } return t; } }…
题目描述 请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径.路径可以从矩阵中的任意一格开始,每一步可以在矩阵中向左.右.上.下移动一格. 如果一条路径经过了矩阵的某一格,那么该路径不能再次进入该格子.例如,在下面的3×4的矩阵中包含一条字符串"bfce"的路径. [["a","b","c","e"], ["s","f","c&quo…
方法:分为几个部分判断 DA[.B][E/eC] D 其中D表示前后的空格,需要处理,跳过即可 A可以带正负号 有符号数 B无符号数 C可以为有符号数(带+-号) 小数点.后面必须是无符号数或者没有 如1.  同时小数点.前面可以没有数字 所以用numeric = findUnsignedInt(s,pos) || numeric(或) E/e前后必须有数字 因此用 numeric = numeric && findInt(s,pos) class Solution { public: b…
题目描述 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 这道题看似简单,其实BUG重重.要注意的问题: 1 关于次幂的问题特殊的情况,比如次幂为负数,或者基数为0时等等复杂的情况 2 机器中浮点数的比较是有误差的,因此double类型的比较,不能用简单的a==0来比较.一般的比较方式是,相减的差在一个很小的区间内,我们就认为是相等的. public static double power(double base, int expo…
/* 题目: 实现函数double Power(double base,int exponent), 求base的exponent次方. */ /* 思路: 本题需要考虑的情况较多: 1.0的负数次方报错. 2.判断double值为0,需要使用精度. 3.考虑exponent为负数的情况. 可创新的点: 求x(n次方),可用x(n/2次方)*2(n/2次方) x为偶数 求x(n次方),可用x(n/2次方)*2(n/2次方)*x x为奇数 */ #include<iostream> #inclu…