7 人赚 960 亿美元,数字天才的首次独舞

巴菲特股东大会

一年一度的巴菲特股东大会如常召开,只不过这次坐在老爷子左手边的不再是老搭档查理芒格,而是钦点的未来继任者,格雷格·阿贝尔。

随着芒格(99岁)的离开,巴菲特(93岁)也曾直言自己已进入加时赛,目前管理巨额资产的核心人数,也从 7 人也变成了 6 位。

去年伯克希尔盈利 962 亿美元,和苹果的 969 亿利润相当。

在长达 5 个小时的大会上,老爷子回答了一些股东问题。

其中比较有意思的,是关于「减持苹果」的问题。

过去很长时间,苹果一直是伯克希尔的第一重仓。

哪怕现在减持了 13%,也仍是第一重仓。

老爷子的回答是认为美国未来会加税,想趁着加税之前降低仓位。

这其实没有说服力,更像是一个敷衍式的回答。

我们都知道巴菲特和芒格都是强调「价值投资」为核心的大师,他们那些经典案例,无不是穿越牛熊。

即使巴菲特有特别的数据或信息来源,也不会是因为单纯的税收政策,因为这变动不足以让伯克希尔卖掉 1000 万股苹果,更何况苹果还是著名的避税公司。

所以,哪怕是巴菲特,不要光听他说什么,要看他做什么。

老爷子在疫情前期还抄底了航空股,高调宣布长期看好航空,结果 2 个月后清仓式的割肉止损呢。

投资者(赌徒)们最喜欢做的事情,就是先射箭后画靶。

减持苹果,归根到底,还是「信心下降」

盲猜老爷子对苹果信心下降是因为「苹果是美国科技公司中的亲中派」、「苹果过去几年缺乏创新,在 AI 等领域落后,重金押注的 AR/VR 领域目前不合预期」、「败诉欧盟,iOS 开放侧载,护城河被撕开口子」等多件事情的叠加。

如果再叠加「此前巴菲特清仓台积电,并公开表示,是因为对地缘形势的担心」的话,或许是中美关系的未来走向,才是主导减持的核心原因。

...

回归主线。

来一道「国内大厂」常考的数据结构题。

题目描述

平台:LeetCode

题号:1670

请你设计一个队列,支持在前,中,后三个位置的 pushpop 操作。

请你完成 FrontMiddleBack 类:

  • FrontMiddleBack() 初始化队列。
  • void pushFront(int val)val 添加到队列的 最前面 。
  • void pushMiddle(int val)val 添加到队列的 正中间 。
  • void pushBack(int val)val 添加到队里的 最后面 。
  • int popFront() 将最前面的元素从队列中删除并返回值,如果删除之前队列为空,那么返回 -1
  • int popMiddle() 将正中间的元素从队列中删除并返回值,如果删除之前队列为空,那么返回 -1
  • int popBack() 将 最后面 的元素从队列中删除并返回值,如果删除之前队列为空,那么返回 -1

请注意当有 两个 中间位置的时候,选择靠前面的位置进行操作。比方说:

  • 6 添加到 [1, 2, 3, 4, 5] 的中间位置,结果数组为 [1, 2, 6, 3, 4, 5]
  • [1, 2, 3, 4, 5, 6] 的中间位置弹出元素,返回 3,数组变为 [1, 2, 4, 5, 6]

示例 1:

输入:
["FrontMiddleBackQueue""pushFront""pushBack""pushMiddle""pushMiddle""popFront""popMiddle""popMiddle""popBack""popFront"]
[[], [1], [2], [3], [4], [], [], [], [], []]

输出:
[null, null, null, null, null, 1, 3, 4, 2, -1]

解释:
FrontMiddleBackQueue q = new FrontMiddleBackQueue();
q.pushFront(1);   // [1]
q.pushBack(2);    // [1, 2]
q.pushMiddle(3);  // [1, 3, 2]
q.pushMiddle(4);  // [1, 4, 3, 2]
q.popFront();     // 返回 1 -> [4, 3, 2]
q.popMiddle();    // 返回 3 -> [4, 2]
q.popMiddle();    // 返回 4 -> [2]
q.popBack();      // 返回 2 -> []
q.popFront();     // 返回 -1 -> [] (队列为空)

提示:

  • 最多调用 pushFrontpushMiddlepushBackpopFrontpopMiddlepopBack

双端队列

只要求在头部或尾部高效插入/弹出元素的话,容易联想到双端队列。

还需要考虑往中间插入/弹出元素的话,会想到使用两个双端队列。

将两个双端队列分别称为 lr,把 lr 拼接起来就是完整元素列表:

alt

由于双端队列本身支持 首尾操作,问题的关键在于如何确保涉及 Middle 操作的高效性。

我们可以设计一个 update 方法,用于确保两队列的相对平衡:

  • 当元素总个数为偶数时,确保两队列元素相等
  • 当元素总个数为奇数时,确保 r 队列比 l 队列元素多一个

如此一来,当我们需要往 Middle 插入元素时,始终往 l 的尾部插入即可;而当需要读取 Middle 位置元素时,根据两队列的元素个数关系决定是从 l 的尾部还是从 r 的头部取元素。

以下是对上述代码中几个操作的简短实现说明:

  • pushFront:将元素添加到 l 队列的头部,调用 update 保持队列平衡
  • pushMiddle:将元素添加到 l 队列的尾部,调用 update 保持队列平衡
  • pushBack:将元素添加到 r 队列的尾部,调用 update 保持队列平衡
  • popFront:若 l 队列不为空,从 l 队列的头部弹出一个元素;否则,从 r 队列的头部弹出一个元素(当且仅当元素个数为 时,队列 l 为空,唯一元素在队列 r 中),调用 update 保持队列平衡
  • popMiddle:若 l 队列和 r 队列的大小相等,则从 l 队列的尾部弹出一个元素;否则,从 r 队列的头部弹出一个元素。调用 update 保持队列平衡
  • popBack:从 r 队列的尾部弹出一个元素,调用 update 保持队列平衡

双端队列的实现,可通过「数组 + 首尾坐标指针」来实现。为方便大家理清脉络,先使用语言自带的 Deque 实现一版。

Java 代码(Deque 版):

class FrontMiddleBackQueue {
    Deque<Integer> l = new ArrayDeque<>(1010), r = new ArrayDeque<>(1010);
    public void pushFront(int val) {
        l.addFirst(val);
        update();
    }
    public void pushMiddle(int val) {
        l.addLast(val);
        update();
    }
    public void pushBack(int val) {
        r.addLast(val);
        update();
    }
    public int popFront() {
        if (l.size() + r.size() == 0return -1;
        int ans = l.size() != 0 ? l.pollFirst() : r.pollFirst();
        update();
        return ans;
    }
    public int popMiddle() {
        if (l.size() + r.size() == 0return -1;
        int ans = l.size() == r.size() ? l.pollLast() : r.pollFirst();
        update();
        return ans;
    }
    public int popBack() {
        if (l.size() + r.size() == 0return -1;
        int ans = r.pollLast();
        update();
        return ans;
    }
    void update() {
        while (l.size() > r.size()) r.addFirst(l.pollLast());
        while (r.size() - l.size() > 1) l.addLast(r.pollFirst());
    }
}

看过 Deque 实现版本,考虑如何使用数组实现。

各类操作的总调用次数最多为 次,我们可创建大小为 的数组,并从下标 (接近中间位置)开始进行存储,这样无论是从前还是往后存数都不会越界。

使用 lhelta 代表队列 l 的头部和尾部坐标,使用 rherta 代表队列 r 的头部和尾部坐标,所有坐标初始值均为

需要注意的是,ta(无论是 lta 还是 rta)是严格指向尾部,因此如果要往尾部插数的话,需要先对指针自增(移到下一个空闲位置),再赋值;而 he(无论是 lhe 还是 rhe)是指向实际队列头部的前一位置,需要先赋值再前移。当 he = ta 代表队列为空。

Java 代码(纯数组版):

class FrontMiddleBackQueue {
    int[] l = new int[2010], r = new int[2010];
    int lhe = 1010, lta = 1010, rhe = 1010, rta = 1010;
    public void pushFront(int val) {
        l[lhe--] = val;
        update();
    }
    public void pushMiddle(int val) {
        l[++lta] = val;
        update();
    }
    public void pushBack(int val) {
        r[++rta] = val;
        update();
    }
    public int popFront() {
        if (getSize(lhe, lta) == 0 && getSize(rhe, rta) == 0return -1;
        int ans = getSize(lhe, lta) != 0 ? l[++lhe] : r[++rhe];
        update();
        return ans;
    }
    public int popMiddle() {
        if (getSize(lhe, lta) + getSize(rhe, rta) == 0return -1;
        int ans = getSize(lhe, lta) == getSize(rhe, rta) ? l[lta--] : r[++rhe];
        update();
        return ans;
    }
    public int popBack() {
        if (getSize(lhe, lta) == 0 && getSize(rhe, rta) == 0return -1;
        int ans = r[rta--];
        update();
        return ans;
    }
    int getSize(int he, int ta) {
        return ta - he;
    }
    void update() {
        while (getSize(lhe, lta) > getSize(rhe, rta)) r[rhe--] = l[lta--];
        while (getSize(rhe, rta) - getSize(lhe, lta) > 1) l[++lta] = r[++rhe];
    }
}

C++ 代码:

class FrontMiddleBackQueue {
public:
    int l[2010], r[2010], lhe = 1010, lta = 1010, rhe = 1010, rta = 1010;
    void pushFront(int val) {
        l[lhe--] = val;
        update();
    }
    void pushMiddle(int val) {
        l[++lta] = val;
        update();
    }
    void pushBack(int val) {
        r[++rta] = val;
        update();
    }
    int popFront() {
        if (getSize(lhe, lta) == 0 && getSize(rhe, rta) == 0return -1;
        int ans = getSize(lhe, lta) != 0 ? l[++lhe] : r[++rhe];
        update();
        return ans;
    }
    int popMiddle() {
        if (getSize(lhe, lta) == 0 && getSize(rhe, rta) == 0return -1;
        int ans = getSize(lhe, lta) == getSize(rhe, rta) ? l[lta--] : r[++rhe];
        update();
        return ans;
    }
    int popBack() {
        if (getSize(lhe, lta) == 0 && getSize(rhe, rta) == 0return -1;
        int ans = r[rta--];
        update();
        return ans;
    }
    int getSize(int he, int ta) {
        return ta - he;
    }
    void update() {
        while (getSize(lhe, lta) > getSize(rhe, rta)) r[rhe--] = l[lta--];
        while (getSize(rhe, rta) - getSize(lhe, lta) > 1) l[++lta] = r[++rhe];
    }
};

Python 代码:

class FrontMiddleBackQueue:
    def __init__(self):
        self.l, self.r = [0] * 2010, [0] * 2010
        self.r = [0] * 2010
        self.lhe, self.lta, self.rhe, self.rta = 1010101010101010

    def pushFront(self, val: int) -> None:
        self.l[self.lhe] = val
        self.lhe -= 1
        self.update()

    def pushMiddle(self, val: int) -> None:
        self.lta += 1
        self.l[self.lta] = val
        self.update()

    def pushBack(self, val: int) -> None:
        self.rta += 1
        self.r[self.rta] = val
        self.update()

    def popFront(self) -> int:
        if self.getSize(self.lhe, self.lta) + self.getSize(self.rhe, self.rta) == 0:
            return -1
        if self.getSize(self.lhe, self.lta) != 0:
            self.lhe += 1
            ans = self.l[self.lhe]
        else:
            self.rhe += 1
            ans = self.r[self.rhe]
        self.update()
        return ans

    def popMiddle(self) -> int:
        if self.getSize(self.lhe, self.lta) + self.getSize(self.rhe, self.rta) == 0:
            return -1
        if self.getSize(self.lhe, self.lta) == self.getSize(self.rhe, self.rta):
            ans = self.l[self.lta]
            self.lta -= 1
        else:
            self.rhe += 1
            ans = self.r[self.rhe]
        self.update()
        return ans

    def popBack(self) -> int:
        if self.getSize(self.lhe, self.lta) + self.getSize(self.rhe, self.rta) == 0:
            return -1
        ans = self.r[self.rta]
        self.rta -= 1
        self.update()
        return ans

    def getSize(self, he: int, ta: int) -> int:
        return ta - he

    def update(self) -> None:
        while self.getSize(self.lhe, self.lta) > self.getSize(self.rhe, self.rta):
            self.r[self.rhe] = self.l[self.lta]
            self.rhe -= 1
            self.lta -= 1
        while self.getSize(self.rhe, self.rta) - self.getSize(self.lhe, self.lta) > 1:
            self.lta += 1
            self.rhe += 1
            self.l[self.lta] = self.r[self.rhe]

TypeScript 代码:

class FrontMiddleBackQueue {
    private l: number[];
    private r: number[];
    private lhe: number;
    private lta: number;
    private rhe: number;
    private rta: number;
    constructor() {
        this.l = Array(2010).fill(0), this.r = Array(2010).fill(0);
        this.lhe = 1010this.lta = 1010this.rhe = 1010this.rta = 1010;
    }
    pushFront(val: number): void {
        this.l[this.lhe--] = val;
        this.update();
    }
    pushMiddle(val: number): void {
        this.l[++this.lta] = val;
        this.update();
    }
    pushBack(val: number): void {
        this.r[++this.rta] = val;
        this.update();
    }
    popFront(): number {
        if (this.getSize(this.lhe, this.lta) + this.getSize(this.rhe, this.rta) == 0return -1;
        const ans = this.getSize(this.lhe, this.lta) != 0 ? this.l[++this.lhe] : this.r[++this.rhe];
        this.update();
        return ans;
    }
    popMiddle(): number {
        if (this.getSize(this.lhe, this.lta) + this.getSize(this.rhe, this.rta) == 0return -1;
        const ans = this.getSize(this.lhe, this.lta) == this.getSize(this.rhe, this.rta) ? this.l[this.lta--] : this.r[++this.rhe];
        this.update();
        return ans;
    }
    popBack(): number {
        if (this.getSize(this.lhe, this.lta) + this.getSize(this.rhe, this.rta) == 0return -1;
        const ans = this.r[this.rta--];
        this.update();
        return ans;
    }
    private getSize(he: number, ta: number): number {
        return ta - he;
    }
    private update(): void {
        while (this.getSize(this.lhe, this.lta) > this.getSize(this.rhe, this.rta)) this.r[this.rhe--] = this.l[this.lta--];
        while (this.getSize(this.rhe, this.rta) - this.getSize(this.lhe, this.lta) > 1this.l[++this.lta] = this.r[++this.rhe];
    }
}
  • 时间复杂度:所有操作复杂度均为
  • 空间复杂度:

进阶

更进一步,使用双向链表并与实现 update 类似效果,维护 Middle 位置的元素节点,同样可实现 各项操作,你能完成吗?

与纯数组版相比,使用链表好处在于可严格按需创建。

class Node {
    Node prev, next;
    int val;
    Node (int _val) {
        val = _val;
    }
}
class FrontMiddleBackQueue {
    Node he, ta, mid;
    int lsz, rsz;
    public FrontMiddleBackQueue() {
        he = new Node(-1); ta = new Node(-1);
        he.next = ta; ta.prev = he;
        mid = ta;
        lsz = rsz = 0;
    }
    public void pushFront(int val) {
        Node cur = new Node(val);
        cur.next = he.next;
        cur.prev = he;
        he.next.prev = cur;
        he.next = cur;
        lsz++;
        update();
    }
    public void pushMiddle(int val) {
        Node cur = new Node(val);
        cur.next = mid;
        cur.prev = mid.prev;
        mid.prev.next = cur;
        mid.prev = cur;
        lsz++;
        update();
    }
    public void pushBack(int val) {
        Node cur = new Node(val);
        cur.next = ta;
        cur.prev = ta.prev;
        ta.prev.next = cur;
        ta.prev = cur;
        rsz++;
        update();
    }
    public int popFront() {
        if (lsz + rsz == 0return -1;
        int ans = he.next.val;
        he.next.next.prev = he;
        he.next = he.next.next;
        lsz--;
        update();
        return ans;
    }
    public int popMiddle() {
        if (lsz + rsz == 0return -1;
        Node realMid = null;
        if (lsz == rsz) {
            realMid = mid.prev;
            lsz--;
        } else {
            realMid = mid;
            mid = mid.next;
            rsz--;
        }
        int ans = realMid.val;
        realMid.prev.next = realMid.next;
        realMid.next.prev = realMid.prev;
        realMid = realMid.next;
        update();
        return ans;
    }
    public int popBack() {
        if (lsz + rsz == 0return -1;
        int ans = ta.prev.val;
        ta.prev.prev.next = ta;
        ta.prev = ta.prev.prev;
        rsz--;
        update();
        return ans;
    }
    void update() {
        while (lsz > rsz) {
            mid = mid.prev;
            lsz--; rsz++;
        }
        while (rsz - lsz > 1) {
            mid = mid.next;
            lsz++; rsz--;
        }
        if (lsz + rsz == 1) mid = ta.prev;
        if (lsz + rsz == 0) mid = ta;
    }
}

最后

给大伙通知一下 📢 :

全网最低价 LeetCode 会员目前仍可用 ~

📅 年度会员:有效期加赠两个月!!; 季度会员:有效期加赠两周!!

🧧 年度会员:获 66.66 现金红包!!; 季度会员:获 22.22 现金红包!!

🎁 年度会员:参与当月丰厚专属实物抽奖(中奖率 > 30%)!!

专属链接:leetcode.cn/premium/?promoChannel=acoier

我是宫水三叶,每天都会分享算法知识,并和大家聊聊近期的所见所闻。

欢迎关注,明天见。

更多更全更热门的「笔试/面试」相关资料可访问排版精美的 合集新基地 🎉🎉

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/595181.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

突破销量瓶颈:亚马逊,速卖通,国际站销量提升实战技巧

1、精心选品&#xff1a;选品是亚马逊销售的第一步&#xff0c;也是至关重要的一步。卖家应该进行市场调研&#xff0c;了解消费者的需求和喜好&#xff0c;选择有市场潜力的产品。要注意产品的差异化&#xff0c;避免与竞争对手的产品过于相似。 2、优化产品详情页&#xff1…

【SpringMVC 】什么是SpringMVC(二)?如何整合ssm框架以及使用mybatisPlus?

文章目录 SpringMVC第三章1、ssm整合1、基本步骤1-3步4-5步6步7步8-12步13步14-15步2、添加数据3、删除数据4、配置事务5、修改数据2、pageHelpe分页1、基本步骤第四章1、mybatisPlus1、基本步骤1-45-7892、基本方法的使用查询2、新ssm项目1、基本步骤1-5678-910-111213-15Spri…

✌粤嵌—2024/4/29—轮转数组

代码实现&#xff1a; // 逆置数组 void nizhi_array(int *nums, int l, int r) { // 左闭右闭if (l > r) {return;}int i l, j r;while (i < j) {int temp nums[i];nums[i] nums[j];nums[j] temp;i;j--;} }void rotate(int *nums, int numsSize, int k) {if (k >…

CSAPP | Chapter 1 | 计算机系统漫游

CSAPP | Chapter 1 | 计算机系统漫游 计算机系统由系统软件与硬件组成。 对于一个简单的 C 程序 hello.c 来说&#xff0c;即便它非常简单&#xff0c;但是为了让它运行&#xff0c;系统的每个主要组成部分都需要协调工作。 #include <stdio.h>int main() {printf(&quo…

AI适老化!10秒一张的AI姓氏头像,居然要卖9块9?中老年用户都说好!

看短视频的你&#xff0c;一定会刷到过这样的直播间&#xff1a; 现在大家明白了&#xff0c;这是一个做姓氏图像的直播间。我刚开始刷到的时候也觉得这种头像好看&#xff0c;高大上&#xff0c;也想做一个这样的图像&#xff0c;来当自己的微信头像。 做这样的图像需要排队刷…

迅饶科技 X2Modbus 网关 AddUser 任意用户添加漏洞复现

0x01 产品简介 X2Modbus是上海迅饶自动化科技有限公司Q开发的一款功能很强大的协议转换网关, 这里的X代表各家不同的通信协议, 2是T0的谐音表示转换, Modbus就是最终支持的标准协议是Modbus协议。用户可以根据现场设备的通信协议进行配置,转成标准的Modbus协议。在PC端仿真…

代码随想录算法训练营DAY43|C++动态规划Part5|1049.最后一块石头的重量II、494.目标和、474.一和零

文章目录 1049.最后一块石头的重量II思路CPP代码 ⭐️494.目标和回溯算法抽象成01背包问题CPP代码本题总结 474.一和零思路CPP代码 1049.最后一块石头的重量II 力扣题目链接 文章链接&#xff1a;1049.最后一块石头的重量II 视频链接&#xff1a;这个背包最多能装多少&#xff…

高中数学-三角函数之常见题型总结

相关公式 新教材&#xff0c;取消了和差化积与积化和差的三角函数题目 例题1 解析 根据条件tanθ -2&#xff0c;我们应该就要想到&#xff0c;把待求式的角向θ靠拢 所以要想到如何降角&#xff0c;将2θ化成θ&#xff0c;那么&#xff0c;想到的公式就是&#xff1a;正弦…

【C++第三阶段】Set Map容器 员工分组案例

以下内容仅为当前认识&#xff0c;可能有不足之处&#xff0c;欢迎讨论&#xff01; 文章目录 Set容器构造和赋值大小和交换插入和删除一次性迭代器&#xff08;可能迅速失效的迭代器&#xff09;长久保留的迭代器如何判断迭代器是否一次性 查找和统计set和multiset的区别pari对…

【notes2】并发,IO,内存

文章目录 1.线程/协程/异步&#xff1a;并发对应硬件资源是cpu&#xff0c;线程是操作系统如何利用cpu资源的一种抽象2.并发&#xff1a;cpu&#xff0c;线程2.1 可见性&#xff1a;volatile2.2 原子性&#xff08;读写原子&#xff09;&#xff1a;AtomicInteger/synchronized…

239 基于matlab的EKF(扩展卡尔曼滤波)_UKF(无迹卡尔曼滤波)_PF(粒子滤波)三种算法的估计结果比较

基于matlab的EKF(扩展卡尔曼滤波)_UKF(无迹卡尔曼滤波)_PF&#xff08;粒子滤波&#xff09;三种算法的估计结果比较&#xff0c;输出估计误差&#xff0c;并单独对粒子滤波进行估计及其置信区间可视化。程序已调通&#xff0c;可直接运行。 239 EKF(扩展卡尔曼滤波) - 小红书 …

Unity | Shader基础知识(第十三集:编写内置着色器阶段总结和表面着色器的补充介绍)

目录 前言 一、表面着色器的补充介绍 二、案例viewDir详解 1.viewDir是什么 2.viewDir的作用 3.使用viewDir写shader 前言 注意观察的小伙伴会发现&#xff0c;这组教程前半部分我们在编写着色器的时候&#xff0c;用的是顶点着色器和片元着色器的组合。 SubShader{CGPRO…

Java转Kotlin

Kotlin 是一种静态编程语言 2011JetBrains开始开发Kotlin&#xff0c;用于多平台应用&#xff08;能脱离虚拟机&#xff0c;直接编译成可以在win,mac,linux运行的二进制代码&#xff09; 2017获得谷歌官方支持 语法简洁&#xff08;减少了大量的样板代码&#xff0c;语法糖&…

【Python深度学习(第二版)(2)】深度学习之前:机器学习简史

文章目录 一. 深度学习的起源1. 概率建模--机器学习分类器2. 早期神经网络--反向传播算法的转折3. 核方法 -- 忽略神经网络4. 决策树、随机森林和梯度提升机5. 神经网络替代svm与决策树 二. 深度学习与机器学习有何不同 可以这样说&#xff0c;当前工业界所使用的大部分机器学习…

服务器端口怎么查,服务器端口查看方法详解

服务器端口是网络通信的关键组件&#xff0c;对于网络管理员和系统管理员来说&#xff0c;了解和掌握如何查看服务器端口是非常重要的。接下来介绍两种常用的方法来查看服务器端口。 方法一&#xff1a;使用命令提示符&#xff08;CMD&#xff09; 1. 首先&#xff0c;点击电脑…

JavaScript百炼成仙自学笔记——12

函数七重关之五&#xff08;自执行函数&#xff09; 什么时候用它&#xff1f; 很多时候&#xff0c;我们只想执行一个函数&#xff0c;却无所谓这个函数叫什么名字。那么这种情况下就可以考虑使用自执行函数。 {function(){console.log(123);} }(); 这就是一个简单的自执行的…

视频剪辑:视频文件元数据修改工具,批量操作提升效率和准确性

在视频剪辑和后期处理的过程中&#xff0c;除了对视频本身的编辑和修改&#xff0c;元数据的管理和修改同样重要。元数据&#xff0c;如标题、艺术家、专辑封面等&#xff0c;不仅提供了视频文件的基本信息&#xff0c;还有助于更好地组织、搜索和共享视频内容。而针对视频文件…

dumpsys meminfo 流程中细节

源码基于&#xff1a;Android U 参考&#xff1a; dumpsys meminfo 详解(R) dumpsys meminfo 详解(U) 1. 命令入口 MemBinder frameworks/base/services/core/java/com/android/server/am/AMS.javastatic class MemBinder extends Binder {ActivityManagerService mActivity…

原型模式和建造者模式

1、原型模式 1.1 概念 用一个已经创建的实例作为原型&#xff0c;通过复制该原型对象来创建一个和原型对象相同的新对象。 1.2 结构 原型模式包含如下角色&#xff1a; 抽象原型类&#xff1a;规定了具体原型对象必须实现的的 clone() 方法。 具体原型类&#xff1a;实现抽…

链表经典面试题01

目录 引言 面试题01:返回倒数第k个节点 题目描述: 思路分析: 代码展示: 面试题02:链表的回文结构 题目描述: 描述 思路分析: 代码展示: 面试题03:相交链表 题目描述: 思路分析: 代码展示: 小结: 引言 这次的题均来自力扣和牛客有关链表的经典面试题,代码只会展示…