LeetCode-2485-找出中枢整数

题目描述:

给你一个正整数 n ,找出满足下述条件的 中枢整数 x :

1 和 x 之间的所有元素之和等于 x 和 n 之间所有元素之和。

返回中枢整数 x 。如果不存在中枢整数,则返回 -1 。题目保证对于给定的输入,至多存在一个中枢整数。

题目链接:LeetCode-2485-找出中枢整数

解题思路:

方法一:双指针:一前一后走,当sumLeft == sumRight并且i==j时退出while循环

方法二:根据数学公式推导
方法一代码实现:

java 复制代码
class Solution {
    public int pivotInteger(int n) {
        // 双指针:一前一后走,当sumLeft == sumRight并且i==j时退出while循环
        int i = 1, j = n;
        int sumLeft = 1, sumRight = n;
        int sum=n*(n+1)/2;
        while (i <= j) {
            if (sumLeft == sumRight) {
                if (i == j) break;
                i++;
                sumLeft += i;
            } else if (sumLeft < sumRight){
                i++;
                sumLeft += i;
            }else {
                j--;
                sumRight += j;
            }
        }
        return i == j ? i : -1;
    }
}

题解可以看官方给的解题思路:传送门

方法二代码实现:

java 复制代码
class Solution {
    public int pivotInteger(int n) {
        int sum=n*(n+1)/2;
        int tmp=(int) Math.sqrt(sum);
        return tmp*tmp==sum ? tmp:-1;
    }
}
相关推荐
彩云回35 分钟前
支持向量机(SVM)
算法·机器学习·支持向量机
Asmalin6 小时前
【代码随想录day 29】 力扣 135.分发糖果
算法·leetcode·职场和发展
微笑尅乐6 小时前
多解法详解与边界处理——力扣7.整数反转
算法·leetcode·职场和发展
夏鹏今天学习了吗6 小时前
【LeetCode热题100(31/100)】K 个一组翻转链表
算法·leetcode·链表
薰衣草23336 小时前
力扣——位运算
python·算法·leetcode
未知陨落6 小时前
LeetCode:83.打家劫舍
算法·leetcode
Pluchon6 小时前
硅基计划4.0 算法 字符串
java·数据结构·学习·算法
三年呀6 小时前
共识算法的深度探索:从原理到实践的全面指南
算法·区块链·共识算法·分布式系统·区块链技术·高性能优化
alex1007 小时前
BeaverTails数据集:大模型安全对齐的关键资源与实战应用
人工智能·算法·安全
麦格芬2307 小时前
LeetCode 416 分割等和子集
数据结构·算法