1、给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。
示例:
给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]
var twoSum = function(nums, target) {
var result
nums.some((item , index) => {
let index1 = nums.indexOf(target - item)
if(index1 > -1 && index1 != index){
result = [ index1 ,index]
}
})
return result
};
2、给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。
示例 1:
输入: 123
输出: 321
示例 2:
输入: -123
输出: -321
示例 3:
输入: 120
输出: 21
注意:
假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为 [−231, 231 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/reverse-integer
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
/**
* @param {number} x
* @return {number}
*/
var reverse = function(x) {
let max=Math.pow(2,31)-1;
let min=-Math.pow(2,31);
if(x >max || x<min){
return 0;
}else{
if(x>0){
let a= parseInt(x.toString().split('').reverse().join(''));
if(a>max){
return 0
}else{
return a
}
}if(x<0){
let b= '-'+ parseInt(x.toString().split('').slice(1,x.length).reverse().join(''))
if(b<min){
return 0
}else{
return b
}
}else{
return 0
}
}
}
console.log(reverse(0))