当前位置: 首页 > article >正文

寒假刷题Day19

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

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. 令牌放置

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

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;
    }
};


http://www.kler.cn/a/528114.html

相关文章:

  • 向上调整算法(详解)c++
  • Linux系统:Ubuntu替换镜像源具体方法;
  • 【设计模式-行为型】备忘录模式
  • 基于排队理论的物联网发布/订阅通信系统建模与优化
  • Leetcode 45. 跳跃游戏 II
  • openssl 生成证书 windows导入证书
  • C#面试常考随笔8:using关键字有哪些用法?
  • 初识Cargo:Rust的强大构建工具与包管理器
  • DBUtils中QueryRunner(空参,传数据源)构造方法的区别及应用场景
  • 智能小区物业管理系统打造高效智能社区服务新生态
  • PHP Mail:高效邮件发送解决方案详解
  • AMS仿真方法
  • SQL进阶实战技巧:断点去重技术详解
  • 鸿蒙物流项目之基础结构
  • 解决Django非ORM模型提示初始化request问题
  • 文件读写操作
  • Sui 年度展望:2025 是走向主流的一年,将 Sui 打造成体验最友好的平台
  • DBeaver连接MySQL提示Access denied for user ‘‘@‘ip‘ (using password: YES)的解决方法
  • MySQL基础-多表查询
  • TensorFlow 示例摄氏度到华氏度的转换(二)
  • MySQL--》日志与主从复制的实战技巧
  • 【VM】VirtualBox安装ubuntu22.04虚拟机
  • 思考:从普通用户的角度而言,大模型选择的初步考量
  • p1044 栈
  • pytorch实现循环神经网络
  • 【开源免费】基于Vue和SpringBoot的医院挂号就诊系统(附论文)