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

[Lc14_priority_queue] 最后一块石头重量 | 数据流中的第 K 大元素 | 前K个高频单词 | 数据流的中位数

目录

1.最后一块石头的重量

题解

2.数据流中的第 K 大元素

题解

3.前K个高频单词

题解

代码

⭕4.数据流的中位数

题解


在C++中,使用标准库中的priority_queue,默认情况下它是一个最大堆(即大堆排序),这意味着最大的元素总是位于队列的前面。具体来说,默认使用的比较器是std::less<T>

1.最后一块石头的重量

链接:1046. 最后一块石头的重量

有一堆石头,每块石头的重量都是正整数。

每一回合,从中选出两块 最重的 石头,然后将它们一起粉碎。假设石头的重量分别为 xy,且 x <= y。那么粉碎的可能结果如下:

  • 如果 x == y,那么两块石头都会被完全粉碎;
  • 如果 x != y,那么重量为 x 的石头将会完全粉碎,而重量为 y 的石头新重量为 y-x

最后,最多只会剩下一块石头。返回此石头的重量。如果没有石头剩下,就返回 0

示例:

输入:[2,7,4,1,8,1]
输出:1
解释:
先选出 7 和 8,得到 1,所以数组转换为 [2,4,1,1,1],
再选出 2 和 4,得到 2,所以数组转换为 [2,1,1,1],
接着是 2 和 1,得到 1,所以数组转换为 [1,1,1],
最后选出 1 和 1,得到 0,最终数组转换为 [1],这就是最后剩下那块石头的重量。

题解

  • 每一回合,从中选出两块 最重的 石头,x == y,那么两块石头都会被完全粉碎;
  • 如果 x != y,那么重量较小的 x 石头将会完全粉碎,而重量较大的 y 的石头新重量为 y-x。
  • 最多只会剩下一块石头。

返回此石头的重量。如果没有石头剩下,就返回 0。

每次挑选的是先挑一堆数中最大的那个数,然后再挑一个剩下数中最大的数。

这不正好符合大根堆的数据结构吗。

解法:用堆来模拟这个过程

先拿数组的数创建一个大根堆,每次从堆里面 选择最大和次大两个数

  • 如果相等就是0不用加入到大根堆里
  • 如果不相等用最大的数减去次大的数,把结果加入到堆里面。

如果最后堆里还剩下一个数,返回这个数。如果堆为空说明石头全都粉碎了返回0即可。

class Solution {
public:int lastStoneWeight(vector<int>& stones) {priority_queue<int> heap;for(auto& n:stones)heap.push(n);while(heap.size()>1){int n1=heap.top();heap.pop();int n2=heap.top();heap.pop();if(n1==n2) continue;else{int tmp=n1>n2?n1-n2:n2-n1;heap.push(tmp);}}return heap.empty()?0:heap.top();   }
};

2.数据流中的第 K 大元素

链接:703. 数据流中的第 K 大元素

设计一个找到数据流中第 k 大元素的类(class)。注意是排序后的第 k 大元素,不是第 k 个不同的元素。

请实现 KthLargest 类:

  • KthLargest(int k, int[] nums) 使用整数 k 和整数流 nums 初始化对象。
  • int add(int val)val 插入数据流 nums 后,返回当前数据流中第 k 大的元素。

示例 1:

输入:
["KthLargest", "add", "add", "add", "add", "add"]
[[3, [4, 5, 8, 2]], [3], [5], [10], [9], [4]]

输出:[null, 4, 5, 5, 8, 8]


题解

设计一个找到数据流中第 k 大元素的类(class)。

注意是 排序后的第 k 大元素,不是第 k 个不同的元素。

int add(int val) 将 val 插入数据流 nums 后,返回当前数据流中第 k 大的元素。

这道题其实考察的是一个非常经典的问题, TopK问题。

  • 关于TopK问题有两种解题思路,一种是堆 O(nlogk),一种是前面刚学的快速选择算法 O(n)(前文回顾:[Lc7_分治-快排] 快速选择排序 | 数组中的第K个最大元素 | 库存管理 III。
  • 快速选择排序虽然快,但是对于海量的数据内存根本放不下。
  • 所以在海量数据情况最优的还是堆。

解法:用 堆 来解决

  1. 创建一个大小为 k 的堆(大根堆 or 小根堆)
  2. 循环
  • 1.依次进堆
  • 2.判断堆的大小是否超过 K

在堆的实现,画图和代码分析建堆,堆排序,时间复杂度以及TOP-K问题,对于求第K个最大元素

  • 我们也是将前K个数建个小堆,然后将剩下的N-K个元素和堆顶元素做比较
  • 如果大于堆顶元素,就先把栈顶元素pop掉,也就是把堆中最小元素删除,然后将它放进去。
  • 这样一直循环,直到所有元素都比较完成。

因为是一直把堆中最小的pop掉,那堆的元素就是N个元素中最大的,而堆顶就是第K个最大的元素

别忘记我们这是一个小堆!

  • sum: eg. TOP_K 大,建一个 K 小堆,大于 top 就 pop,push, 最后的就是第 K 大了,因为是一个 数值为 K 的小堆

这里我们也是建小堆,依次进堆,当堆大小超过K个,pop堆顶元素,把堆中最小元素pop掉,并且使堆保持K个大小。

每次都是堆中最小元素去掉。那最后堆中剩下的就是前K个最大元素,而堆顶就是第K个最大元素。

考虑一下下面两个问题

  • 用大根堆还是小根堆
  • 为什么要用大根堆(小根堆)
class KthLargest {
public:priority_queue<int,vector<int>,greater<int>> heap;int _k;KthLargest(int k, vector<int>& nums) {//第k大,建小堆_k=k;for(auto& num:nums){heap.push(num);if(heap.size()>k) heap.pop();//删除最小的}}int add(int val) {heap.push(val);if(heap.size()>_k) heap.pop();//删除最小的return heap.top();}
};

3.前K个高频单词

链接:692. 前K个高频单词

给定一个单词列表 words 和一个整数 k ,返回前 k 个出现次数最多的单词。

返回的答案应该按单词出现频率由高到低排序。如果不同的单词有相同出现频率, 按字典顺序 排序。

示例 1:

输入: words = ["i", "love", "leetcode", "i", "love", "coding"], k = 2
输出: ["i", "love"]
解析: "i" 和 "love" 为出现次数最多的两个单词,均为2次。注意,按字母顺序 "i" 在 "love" 之前。

示例 2:

输入: ["the", "day", "is", "sunny", "the", "the", "the", "sunny", "is", "is"], k = 4
输出: ["the", "is", "sunny", "day"]
解析: "the", "is", "sunny" 和 "day" 是出现次数最多的四个单词,出现次数依次为 4, 3, 2 和 1 次。

题解

这是一个TopK的问题,注意,返回的答案应该按单词出现频率由高到低排序。

如果不同的单词有相同出现频率, 按字典顺序(由低向高) 排序。

解法:利用 “堆” 来解决 TopK 问题

  • 1. 预处理一下原始的字符串数组: 用一个哈希表,统计一下每一个单词出现的频次。

  • 2. 创建一个大小为 k 的堆,类提供的比较函数满足不了要求,我们要自己定义一个!

(返回的答案应该按单词出现频率由高到低排序。如果不同的单词有相同出现频率, 按字典顺序(由低向高) 排序。)

如果比较频次创建一个小根堆,如果比较字典序(频次相同的时候),创建一个大根堆。

所以说创建堆写比较函数的时候必须要考虑这两点

  • 当频次相同的时候字典序按照大根堆方式比较
  • 当频次不同的时候按照小根堆方式比较。

  • 3. 循环

1.依次进堆

2.判断堆的大小是否超过 K

  • 4. 提取结果
  • 因为求前K大,所以建的是一个小根堆,然后提取堆顶元素在pop是一个升序的。
  • 逆序一下取前K个

代码

#和 ds 讨论后的优化代码,用lambda和emplace

⭕4.数据流的中位数

链接:295. 数据流的中位数

中位数是有序整数列表中的中间值。如果列表的大小是偶数,则没有中间值,中位数是两个中间值的平均值。

  • 例如 arr = [2,3,4] 的中位数是 3
  • 例如 arr = [2,3] 的中位数是 (2 + 3) / 2 = 2.5

实现 MedianFinder 类:

  • MedianFinder() 初始化 MedianFinder 对象。
  • void addNum(int num) 将数据流中的整数 num 添加到数据结构中。
  • double findMedian() 返回到目前为止所有元素的中位数。与实际答案相差 10-5 以内的答案将被接受。

示例 1:

输入
["MedianFinder", "addNum", "addNum", "findMedian", "addNum", "findMedian"]
[[], [1], [2], [], [3], []]
输出
[null, null, null, 1.5, null, 2.0]解释
MedianFinder medianFinder = new MedianFinder();
medianFinder.addNum(1);    // arr = [1]
medianFinder.addNum(2);    // arr = [1, 2]
medianFinder.findMedian(); // 返回 1.5 ((1 + 2) / 2)
medianFinder.addNum(3);    // arr[1, 2, 3]
medianFinder.findMedian(); // return 2.0

题解

给一个数据流,让返回每次当前已经加入到数组的数据流的中位数。

中位数是有序整数列表中的中间值。

  • 如果列表的大小是偶数,则没有中间值,中位数是两个中间值的平均值。
  • 表的大小是奇数,直接返回中间的数。

解法一:直接sort

每次从数据流中来一个数插入数组中之后,都对当前数组进行sort

然后通过下标的方式找到中间数。

每次add加入一个数都要sort,时间复杂度是O(nlogn)。

  • 总体时间复杂度是非常恐怖的。
  • 因为是下标访问,find 时间复杂度是 O(1)

解法二:插入排序的思想

[0,end] 有序,插入 end + 1,使 [0, end + 1]有序。

这道题正好就是这样的思想。

相当于打扑克,找到合适的位置。

add函数,每次插入一个数的时候都需要从后往前扫描找一个插入的位置

  • 因此时间复杂度是O(n)
  • find 也是通过下标去找 时间复杂度是O(1)

解法三:大小堆来维护数据流的中位数

此时有一个数轴已经按照从小到大的排好序了,这个时候想找中间数的时候。

  • 把这些数的前半部分放到一个大根堆里面,后半部分放到小根堆里面。
  • 此时找中间值也很快,前面较小的数放到大根堆里面,堆顶元素是数轴中这些较小元素种最右边的值。
  • 后面较大的数放到小根堆里面,堆顶元素是数轴中这些较大元素最左边。

此时我们仅需根据数组中的元素的个数就可以求出中位数是多少了。

如果数组是偶数

  • 大根堆和小根堆正好把数轴平分
  • 然后 大堆堆顶元素和小堆堆顶元素相加 /2就是这个数组的中位数。

如果数组是奇数个。

  • 我们就先人为规定一下,数轴左边元素是m个,右边是n个
  • 人为规定左边大根堆多方一个元素,m > n (m = n + 1)
  • 此时中位数就是 左边大根堆的堆顶元素。

向这样用大根堆存左边较小部分,小根堆存右边较大部分。

  • find 时间复杂度也是O(1),而add快了很多
  • 因为我们是从堆存这些元素的,插入和删除每次调整堆仅需O(logn)

细节问题:

add如何实现:

  • 假设现在有两个堆了。
  • 一个大根堆left,一个小根堆right。
  • left元素个数m个,right元素个数n个,left堆顶元素x,right堆定元素y。

如果此时来了一个数num,num要么放在left里,要么放在right里。

但是放好之后可能会破坏之前的规则:

  • m == n
  • m > n —> m == n + 1

我们必须维护上面的规则,才能正确找到数组中位数。

接下来分情况讨论:

m == n

  • num要么插入left,要么插入right。
  • 如果num要进入left,那么num <= x,但是别忘记 m == n 有可能两个堆全为空,num也是直接进入left。
  • 此时 m 比 n 多了一个。没关系直接进就行。

如果num进入right,那条件是 num > x。

  • 此时就有问题了。n > m了,而 n > m是不被允许的,所以我们要把右边堆调整一下,就是拿right堆顶元素放到left里。
  • 因为right是一个小根堆,堆顶就是最小值。
  • 拿到left,还是能保证left堆里元素是较小的,right堆里元素是较大的。
  • 拿right堆顶元素放到left里正好满足 m == n + 1。

这里有一个细节问题,必须num先进right堆,然后再拿right堆定元素放到left

因为 x < num < y,如果直接把y拿过去了,就破坏了left都是较小元素。right都是较大元素。

m > n —> m == n + 1

如果num进入left,那么num <= x , 但是此时不满足 m == n + 1

  • 因此 进栈后将栈顶元素给right。
  • 如果num进入right,那么num > x , m == n了,直接进就行了

注意: 上面都是 先进栈 再拿栈顶移动

顺便复习了大顶堆小顶堆,红黑树,avl树,排序。很好的题

class MedianFinder {
private:std::priority_queue<int> left;    // 大顶堆存较小的一半std::priority_queue<int, std::vector<int>, std::greater<int>> right; // 小顶堆存较大的一半public:MedianFinder() {}  // 构造函数不需要初始化队列void addNum(int num) {int m=left.size();int n=right.size();if(m==n){if(m==0 || num<=left.top())//注意为空left.push(num);else{right.push(num);left.push(right.top());right.pop();}}if(m>n){if(num<=left.top()){left.push(num);right.push(left.top());left.pop();}//先 进栈 再拿栈顶移动elseright.push(num);}}double findMedian() {if(left.size() > right.size()) {return left.top();}return (left.top() + right.top()) / 2.0;  // 2.0确保浮点运算}
};

相关文章:

[Lc14_priority_queue] 最后一块石头重量 | 数据流中的第 K 大元素 | 前K个高频单词 | 数据流的中位数

目录 1.最后一块石头的重量 题解 2.数据流中的第 K 大元素 题解 3.前K个高频单词 题解 代码 ⭕4.数据流的中位数 题解 在C中&#xff0c;使用标准库中的priority_queue&#xff0c;默认情况下它是一个最大堆&#xff08;即大堆排序&#xff09;&#xff0c;这意味着最…...

熔断和降级的区别,具体使用场景有哪些?

熔断与降级的核心区别在于触发条件和应用目标&#xff0c;具体差异及使用场景如下&#xff1a; 一、核心区别 对比维度熔断降级触发原因下游依赖服务故障&#xff08;如超时、异常率过高&#xff09;触发系统整体负载过高或流量洪峰管理目标层级框架级保护&#xff08;无业务优…...

利用hexo+github部署属于自己的个人博客网站(2025年3月所写)

利用hexogithub部署属于自己的个人博客网站 前情提要&#xff1a;如果你出现了莫名其妙的报错&#xff0c;可能与权限有关&#xff0c;可以以管理员的身份运行git bash或者cmd 本篇博客仅限于利用hexo搭建博客&#xff0c;并且部署到github上面&#xff0c;让自己可以有一个访…...

首页性能优化

首页性能提升是前端优化中的核心任务之一&#xff0c;因为首页是用户访问的第一入口&#xff0c;其加载速度和交互体验直接影响用户的留存率和转化率。 1. 性能瓶颈分析 在优化之前&#xff0c;首先需要通过工具分析首页的性能瓶颈。常用的工具包括&#xff1a; Chrome DevTo…...

使用usb-cam包时填充摄像头参数话题

问题描述&#xff1a; 在启动usb摄像头之后&#xff0c;像apriltag_ros等包需要读取摄像头的内参信息&#xff0c;但是usb-cam默认是没有内参信息发布的&#xff0c;需要自己填写或标定。 解决方案&#xff1a; 如果你有内参数据或者急于验证后续代码的逻辑正确性&#xff0c…...

pandas学习笔记(一)——基础知识和应用案例

pandas学习笔记 基础语法参考菜鸟教程&#xff1a;https://www.runoob.com/pandas/pandas-tutorial.html # jupyter import pandas as pd import matplotlib from matplotlib import pyplot as plt import numpy as npmatplotlib.use(TkAgg)data {timestamp: [1, 2, 3, 4, 5…...

SpringBoot + Mybatis Plus 整合 Redis

Redis 在用户管理系统中的典型应用场景 结合你的用户增删改查接口&#xff0c;以下是 Redis 的实用场景和具体实现方案&#xff1a; 场景作用实现方案用户信息缓存减少数据库压力&#xff0c;加速查询响应使用 Spring Cache Redis 注解缓存登录 Token 存储分布式 Session 或…...

【AI 大模型】RAG 检索增强生成 ⑤ ( 向量数据库 | 向量数据库 索引结构和搜索算法 | 常见 向量数据库 对比 | 安装并使用 向量数据库 chromadb 案例 )

文章目录 一、向量数据库1、向量数据库引入2、向量数据库简介3、向量数据库 索引结构和搜索算法4、向量数据库 应用场景5、传统数据库 与 向量数据库 对比 二、常见 向量数据库 对比三、向量数据库 案例1、安装 向量数据库 chromadb2、核心要点 解析① 创建数据库实例② 创建数…...

解决single cell portal点击下载但跳转的是网页

Single cell RNA-seq of Tmem100-lineage cells in a mouse model of osseointegration - Single Cell Portal 想下载个小鼠数据集&#xff1a; 点击下载跳转为网页&#xff1a; 复制bulk download给的链接无法下载 bulk download给的原链接&#xff1a; curl.exe "http…...

基于 Prometheus + Grafana 监控微服务和数据库

以下是基于 Prometheus Grafana 监控微服务和数据库的详细指南&#xff0c;包含架构设计、安装配置及验证步骤&#xff1a; 一、整体架构设计 二、监控微服务 1. 微服务指标暴露 Spring Boot 应用&#xff1a; xml <!-- 添加 Micrometer 依赖 --> <dependency>…...

GitHub Copilot 在 VS Code 上的终极中文指南:从安装到高阶玩法

GitHub Copilot 在 VS Code 上的终极中文指南&#xff1a;从安装到高阶玩法 前言 GitHub Copilot 作为 AI 编程助手&#xff0c;正在彻底改变开发者的编码体验。本文将针对中文开发者&#xff0c;深度解析如何在 VS Code 中高效使用 Copilot&#xff0c;涵盖基础设置、中文优化…...

为什么选择 Rust 和 WebAssembly?

一、低级控制与高级体验 在 Web 应用开发中&#xff0c;JavaScript 虽然灵活&#xff0c;但往往难以保证稳定的性能。其动态类型系统和垃圾回收&#xff08;GC&#xff09;机制会导致性能波动&#xff0c;甚至在不经意间因偏离 JIT&#xff08;即时编译器&#xff09;的最佳路…...

Vala语言基础知识-源文件和编译

源文件和编译 Vala代码‌以.vala为扩展名。与Java等语言不同&#xff0c;Vala‌不强制要求严格的文件结构‌——它没有类似Java的"包"&#xff08;package&#xff09;或"类文件"&#xff08;class file&#xff09;的概念&#xff0c;而是通过文件内的文本…...

CAN总线的CC帧和FD帧之间如何仲裁

为满足CAN总线日益提高的带宽需求&#xff0c;博世公司于2012年推出CAN FD&#xff08;具有灵活数据速率的CAN&#xff09;标准&#xff0c;国际标准化组织&#xff08;ISO&#xff09;2015年通过ISO 11898-1:2015标准&#xff0c;正式将CAN FD纳入国际标准&#xff0c;以示区别…...

SpringBoot 第一课(Ⅲ) 配置类注解

目录 一、PropertySource 二、ImportResource ①SpringConfig &#xff08;Spring框架全注解&#xff09; ②ImportResource注解实现 三、Bean 四、多配置文件 多Profile文件的使用 文件命名约定&#xff1a; 激活Profile&#xff1a; YAML文件支持多文档块&#xff…...

Python的类和对象(4)

1、反射 动态的给类和对象添加属性&#xff0c;获取属性&#xff0c;删除属性&#xff0c;修改属性【反射】。 --4个内置函数 1&#xff09;设置属性&#xff1a;setattr( 对象/类&#xff0c;属性名&#xff0c;属性值) 2&#xff09;获取属性&#xff1a;getattr(对象/类&am…...

使用EasyExcel进行简单的导入、导出

准备 在pom.xml添加依赖 <!-- EasyExcel --><dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.1.1</version></dependency>导入 controller // 用户导入Operation(summary…...

Excel(函数篇):COUNTIF与CONUTIFS函数、SUMIF与SUMIFS函数、ROUND函数、MATCH与INDEX函数、混合引用与条件格式

目录 COUNTIF和COUNTIFS函数COUNTIF函数COUNTIFS函数SUMIF和SUMIFS函数SUMIF函数SUMIFS函数SUMIFS函数与控件实现动态年月汇总ROUND、ROUNDUP、ROUNDDOWN函数单元格混合引用条件格式与公式,标记整行数据MATCH和INDEX函数COUNTIF和COUNTIFS函数 COUNTIF函数 统计下“苏州”出现…...

虚拟定位 1.2.0.2 | 虚拟定位,上班打卡,校园跑步模拟

Fake Location是一款运行于安卓平台上的功能强大、简单实用的虚拟定位软件。它能够帮助用户自定义位置到地图上的任意地方&#xff0c;以ROOT环境运行不易被检测&#xff0c;同时也支持免ROOT运行。提供路线模拟、步频模拟、WIFI模拟等方式&#xff0c;支持反检测。 大小&…...

【最大异或和——可持久化Trie】

题目 代码 #include <bits/stdc.h> using namespace std;const int N 6e510; //注意这里起始有3e5&#xff0c;又可能插入3e5 const int M N * 25;int rt[N], tr[M][2]; //根&#xff0c;trie int idx, cnt, br[M]; //根分配器&#xff0c;点分配器&#xff0c;点的相…...

C# WPF编程-启动新窗口

C# WPF编程-启动新窗口 新建窗口&#xff1a; 工程》添加》窗口 命名并添加新的窗口 这里窗口名称为Window1.xaml 启动新窗口 Window1 win1 new Window1(); win1.Show(); // 非模态启动窗口win1.ShowDialog(); // 模态启动窗口 模态窗口&#xff1a;当一个模态窗口被打开时&a…...

数据库:MySQL 指令大全(备忘清单)

文章目录 入门介绍登录MySQL常用的数据库 Database表 TableProccess 查看 MySQL 信息退出MySQL会话备份 MySQL 示例管理表格从表中查询数据从多个表查询使用 SQL 约束修改数据管理视图管理触发器WHENEVENTTRIGGER_TYPE 管理索引 MySQL 数据类型StringsDate & timeNumeric 函…...

NET进行CAD二次开发之二

本文主要针对CAD 二次开发入门与实践:以 C# 为例_c# cad-CSDN博客的一些实践问题做一些补充。 一、DLL介绍 在 AutoCAD 中,accoremgd.dll、acdbmgd.dll 和 acmgd.dll 都是与.NET API 相关的动态链接库,它们在使用.NET 语言(如 C#、VB.NET)进行 AutoCAD 二次开发时起着关…...

Python 实现大文件的高并发下载

项目背景 基于一个 scrapy-redis 搭建的分布式系统&#xff0c;所有item都通过重写 pipeline 存储到 redis 的 list 中。这里我通过代码演示如何基于线程池 协程实现对 item 的中文件下载。 Item 结构 目的是为了下载 item 中 attachments 保存的附件内容。 {"crawl_tim…...

【最新】 ubuntu24安装 1panel 保姆级教程

系统&#xff1a;ubuntu24.04.1 安装软件 &#xff1a;1panel 第一步&#xff1a;更新系统 sudo apt update sudo apt upgrade 如下图 第二步&#xff1a;安装1panel&#xff0c;运行如下命令 curl -sSL https://resource.fit2cloud.com/1panel/package/quick_start.sh -o …...

c++图论(二)之图的存储图解

在 C 中实现图的存储时&#xff0c;常用的方法包括 邻接矩阵&#xff08;Adjacency Matrix&#xff09;、邻接表&#xff08;Adjacency List&#xff09; 和 边列表&#xff08;Edge List&#xff09;。以下是具体实现方法、优缺点分析及代码示例&#xff1a; 1. 邻接矩阵&…...

c++图论(一)之图论的起源和图的概念

C 图论之图论的起源和图的概念 图论&#xff08;Graph Theory&#xff09;是数学和计算机科学中的一个重要分支&#xff0c;其起源可以追溯到 18 世纪 的经典问题。以下是图论的历史背景、核心起源问题及其与基本概念和用途&#xff1a; 借用一下CSDN的图片哈 一、图论的起源&…...

《Python深度学习》第二讲:深度学习的数学基础

本讲来聊聊深度学习的数学基础。 深度学习听起来很厉害,其实它背后是一些很有趣的数学原理。本讲会用简单的方式解释这些原理,还会用一些具体的例子来帮助你理解。 2.1 初识神经网络 先从一个简单的任务开始:识别手写数字。 想象一下,你有一堆手写数字的图片,你想让计算…...

ChatGPT and Claude国内使用站点

RawChat kelaode chatgptplus chatopens&#xff08;4.o mini免费&#xff0c;plus收费&#xff09; 网页&#xff1a; 定价&#xff1a; wildcard 网页&#xff1a; 虚拟卡定价&#xff1a; 2233.ai 网页&#xff1a; 定价&#xff1a; MaynorAPI chatgpt cla…...

进行性核上性麻痹:精心护理,点亮希望之光

进行性核上性麻痹是一种罕见的神经退行性疾病&#xff0c;严重影响患者的生活质量。有效的健康护理能够在一定程度上缓解症状、延缓病情发展&#xff0c;给患者带来更好的生活体验。 在日常生活护理方面&#xff0c;由于患者平衡能力逐渐下降&#xff0c;行动不便&#xff0c;居…...