寒假刷题Day19

一、923. 三数之和的多种可能

cpp 复制代码
class Solution {
public:
    int threeSumMulti(vector<int>& arr, int target) {
       const int MOD = 1'000'000'007; // 正确的模数
        long long ans = 0; // 使用 long long 防止溢出
        std::sort(arr.begin(), arr.end());

        for (size_t i = 0; i < arr.size(); ++i) {
            int T = target - arr[i];
            size_t j = i + 1, k = arr.size() - 1;

            while (j < k) {
                if (arr[j] + arr[k] < T) {
                    j++;
                } else if (arr[j] + arr[k] > T) {
                    k--;
                } else if (arr[j] != arr[k]) { 
                    int left = 1, right = 1;
                    while (j + 1 < k && arr[j] == arr[j + 1]) {
                        left++;
                        j++;
                    }
                    while (k - 1 > j && arr[k] == arr[k - 1]) {
                        right++;
                        k--;
                    }

                    ans += static_cast<long long>(left) * right; // 避免溢出
                    ans %= MOD;
                    j++;
                    k--;
                } else {
                    long long M = k - j + 1;
                    ans += (M * (M - 1) / 2) % MOD; // 避免溢出
                    ans %= MOD;
                    break;
                }
            }
        }

        return static_cast<int>(ans);
    }
};

static_cast<long>(value)在编译时进行类型转换,比c风格的(long)value更安全更清晰

二、948. 令牌放置

思路:点数小的得分,大的吃掉,当不够获得最小令牌的分时候,吃一个最大的令牌

cpp 复制代码
class Solution {
public:
    int bagOfTokensScore(vector<int>& tokens, int P) {
        if (tokens.empty()) return 0;
        sort(tokens.begin(), tokens.end());
        if (P < tokens[0]) return 0;
        int N = tokens.size();
        int left = 0;
        int right = N - 1;
        int score = 0;
        int res = 0;
        while (left <= right) {
            if (P < tokens[left]) {
                if (score <= 0) return res;
                P += tokens[right];
                --score;
                --right;
            } else {
                P -= tokens[left];
                ++score;
                ++left;
                res = max(res, score);
            }
        }
        return res;
    }
};
相关推荐
MeAT ITEM1 分钟前
ShardingSphere-jdbc 5.5.0 + spring boot 基础配置 - 实战篇
java·spring boot·后端
ekuoleung3 分钟前
Spring Boot 3.4 + Java 21 在量化平台中的架构实践
java·架构
周杰伦fans5 分钟前
C# CAD二次开发:RotatedDimension 文字边框设置完全指南
开发语言·c#
Black蜡笔小新13 分钟前
国标GB28181视频监控平台EasyCVR赋能平安乡村建设,构筑乡村治理“数字防线”
java·网络·音视频
蚰蜒螟16 分钟前
从 pthread_create 到 thread_native_entry:glibc 如何唤醒 Java 线程
java·开发语言
We་ct19 分钟前
LeetCode 300. 最长递增子序列:两种解法从入门到优化
开发语言·前端·javascript·算法·leetcode·typescript
gCode Teacher 格码致知20 分钟前
Python提高: unittest和 pytest的使用方法-由Deepseek产生
开发语言·python·pytest
callJJ32 分钟前
JVM 类加载机制详解——从 .class 文件到对象诞生的完整旅程
java·jvm·类加载·双亲委派模型
Johnstons38 分钟前
网络可观测性落地指南:从“出了问题才排查“到“实时感知全网状态“
开发语言·网络·php
️是7844 分钟前
信息奥赛一本通—编程启蒙(3371:【例64.2】 生日相同)
开发语言·c++·算法