LeetCode Hot100 (2、3、4、5、6、8、9、12)

news2025/5/19 0:01:17

题2--字母异或位分词

class Solution {
public:
    vector<vector<string>> groupAnagrams(vector<string>& strs) {

      //  一开始的思路是,对于其中的一个单词,遍历所有排序组合,然后判断这些组合是否在哈希表里
      //,在的话就加入数组,然后从哈希表里删掉,问题是如何遍历所有排序组合,dfs?
      //这里学习一种方法,将哈希表中的不同字符串排序,如果排序后是相等的就代表字母一样
      //如果有这种思路,就很简单了,依次遍历数组,看他排序后的字符串是否在哈希表里,在就修改哈希表的值,不在就加入这个key

      unordered_map<string,vector<string>> m;

      for(int i=0;i<strs.size();i++)
      {
      string str=strs[i];
      sort(str.begin(),str.end());
      m[str].emplace_back(strs[i]);
      
      }

vector<vector<string>> s;
 for(auto t:m)
 {
    s.emplace_back(t.second);
 }

return s;

   


    }
};
 1.push_back vs emplace_back
函数行为性能影响适用场景
push_back接受一个 ​​已构造的对象​​,通过拷贝或移动操作添加到容器末尾若传递临时对象(如右值),触发移动构造(比拷贝快);若传递左值,触发拷贝构造当已持有构造好的对象时使用
emplace_back直接在容器内存中 ​​构造对象​​,无需创建临时对象完全避免拷贝/移动操作,​​性能更优​​(尤其对复杂对象)需要直接构造对象时使用(传递构造参数而非对象本身)
  • 对于简单类型(如 intdouble):两者性能几乎相同。
  • 对于复杂类型(如 std::string, 自定义类):emplace_back 效率更高(减少一次拷贝/移动)。
  • 对于不可拷贝/移动的对象(如 std::unique_ptr):​​必须使用 emplace_back​。
  • 在 C++11 及以上环境中,​​优先使用 emplace_back​。
2.vector 常用操作表格
操作函数用途时间复杂度
​添加元素​push_back(const T& value)在末尾添加元素的拷贝O(1) 均摊
emplace_back(Args&&... args)在末尾直接构造元素O(1) 均摊
​删除元素​pop_back()删除末尾元素O(1)
​容量查询​size()返回元素数量O(1)
empty()判断是否为空O(1)
​内存管理​reserve(size_type n)预分配至少容纳 n 个元素的内存O(n)
capacity()返回当前分配的内存容量O(1)
shrink_to_fit()释放未使用的内存(C++11起)O(n)
​修改大小​resize(size_type n)调整元素数量(多删少补默认值)O(n)
resize(size_type n, const T& value)调整元素数量(多删少补指定值)O(n)
​元素访问​operator[]通过下标访问(无边界检查)O(1)
at(size_type pos)通过下标访问(有边界检查)O(1)
front()访问第一个元素O(1)
back()访问最后一个元素O(1)
​批量操作​insert(iterator pos, InputIt first, InputIt last)在指定位置插入区间元素O(n + m)
erase(iterator pos)删除指定位置元素O(n)
clear()清空所有元素(不释放内存)O(n)
​迭代器​begin() / end()获取首尾迭代器O(1)

string类型基础操作

 string类型的排序是通过 begin() end()

1.构造与赋值​
操作函数/语法描述示例注意事项
​默认构造​string s;创建空字符串string s;初始为空
​拷贝构造​string s(str);复制另一个字符串string s2(s1);深拷贝
​C 字符串构造​string s("text");从 C 风格字符串构造string s("hello");自动计算长度
​重复字符构造​string s(n, 'c');创建含 n 个字符的字符串string s(5, 'a'); → "aaaaa"字符需明确
​移动构造​​ (C++11)string s(std::move(str));转移另一个字符串的内容string s2 = std::move(s1);原字符串失效
​赋值操作符​s = "text";用新内容覆盖原字符串s = "world";支持多种类型
​assign()​s.assign(str);重新赋值s.assign("test", 3); → "tes"可指定长度

​2.元素访问​
操作函数/语法描述示例注意事项
​下标访问​s[i]访问第 i 个字符char c = s[0];不检查越界
​at()​s.at(i)访问第 i 个字符(检查越界)char c = s.at(0);越界抛出 out_of_range
​front()​s.front()访问第一个字符char c = s.front();等价于 s[0]
​back()​s.back()访问最后一个字符char c = s.back();等价于 s[s.size()-1]
​data()​s.data()返回指向字符数组的指针const char* p = s.data();非终止符(C++11 前)
​c_str()​s.c_str()返回 C 风格字符串(以 \0 结尾)printf("%s", s.c_str());指针不可修改

​3.修改操作​
操作函数/语法描述示例注意事项
​append()​s.append(str);追加字符串s.append("world");支持多种类型
​push_back()​s.push_back('c');追加单个字符s.push_back('!');等价于 s += 'c'
​insert()​s.insert(pos, str);在指定位置插入字符串s.insert(2, "xx"); → "hexxllo"位置需有效
​erase()​s.erase(pos, len);删除从 pos 开始的 len 个字符s.erase(1, 2); → "hlo"默认删到结尾
​replace()​s.replace(pos, len, str);替换部分内容s.replace(0, 2, "HE"); → "HEllo"长度可动态调整
​clear()​s.clear();清空字符串s.clear(); → s.empty() 为 true容量可能保留
​swap()​s1.swap(s2);交换两个字符串的内容s1.swap(s2);高效(O(1))

​4.查找与子字符串​
操作函数/语法描述示例注意事项
​find()​s.find(str, pos);查找子字符串首次出现的位置s.find("ll"); → 2未找到返回 string::npos
​rfind()​s.rfind(str, pos);查找子字符串最后一次出现的位置s.rfind("l"); → 3反向搜索
​find_first_of()​s.find_first_of(chars);查找字符集中任意字符首次出现的位置s.find_first_of("aeiou"); → 1匹配集合
​substr()​s.substr(pos, len);提取子字符串s.substr(1, 3); → "ell"默认到结尾

​5.容量操作​
操作函数/语法描述示例注意事项
​size() / length()​s.size();返回字符数量int len = s.size();两者等价
​empty()​s.empty();判断是否为空if (s.empty()) {...}等价于 size() == 0
​resize()​s.resize(n, 'c');调整字符串长度s.resize(10, 'x'); → "helloxxxxx"默认填充 \0
​capacity()​s.capacity();返回当前分配的内存容量int cap = s.capacity();通常 ≥ size()
​reserve()​s.reserve(n);预分配内存(避免重复扩容)s.reserve(100);不影响 size()
​shrink_to_fit()​​ (C++11)s.shrink_to_fit();释放多余内存s.shrink_to_fit();容量可能减少

​6.比较与连接​
操作函数/语法描述示例注意事项
​比较操作符​==!=<>, etc.按字典序比较字符串if (s1 < s2) {...}区分大小写
​compare()​s.compare(str);返回字典序比较结果s.compare("apple"); → 正数/负数/0类似 strcmp
​连接操作符​s1 + s2;连接两个字符串string s3 = s1 + s2;生成新对象
​+= 操作符​s1 += s2;追加内容到字符串s1 += "world";直接修改原字符串

​7.其他操作​
操作函数/语法描述示例注意事项
​迭代器访问​s.begin()s.end()获取迭代器for (auto it = s.begin(); it != s.end(); ++it) {...}支持范围 for 循环
​数值转换​​ (C++11)stoi()to_string()字符串与数值互转int num = stoi("123");

题3--最长连续序列

自己想的方法,没有达到n复杂度,在n到n方之间,能通过74/81

class Solution {
public:
    int longestConsecutive(vector<int>& nums) {
        //题目要求的是n的复杂度,也就是说在遍历一遍或者几遍数组后就应该得出答案
        //一开始的思路是像前几道哈希表一样,依次遍历每个数,然后看这个数的前一个数和后一个
        //在不在哈希表里,但是涉及到一个问题,比如 1 2 3 4 0,遍历到2的时候可以去更新1的值,遍历到4的时候还能去更新1吗,这样复杂度就说n方了
        //n复杂度不代表遍历一次数组就得出答案,遍历几次也行
        //直接先将所有数放入哈希表,且全部为1(此时没有重复)
        //然后遍历哈希表,只判断这个数的前一个数在不在,然后更新这个数的值,每个数更新后的值代表以这个数结尾的连续序列的长度
        //此时还有一个问题,就是哈希表里是乱序,所以,你便利到当前这个值,你的值取决于你上一个数的值,但是你要去判断,你下一个数的值可能在之前你还没变的时候就变了
        //此时要一直往前判断,不过没关系,这是有限次的,复杂度还是n
unordered_map<int,int> m;

for(int i=0;i<nums.size();++i)m[nums[i]]=1;

for(auto t:m)
{
int a=t.first;
  if(m.find(a-1)!=m.end())m[a]=m[a-1]+1;
while(m.find(a+1)!=m.end())
{
    if(m[a+1]<=m[a]&&m[a+1]!=1){
        m[a+1]=m[a]+1;
            ++a;
    }else
    {
        break;//如果存在且没有被错误更新就直接break,如果没有这一步就全错了,所以有if一定要考虑else
    }
}


}



int u=0;
for(auto t:m)
{
u=max(u,t.second);

}


return u;



    }
};


官方题解:

class Solution {
public:
    int longestConsecutive(vector<int>& nums) {
//每个数都判断一次这个数是不是连续序列的开头那个数。
// 怎么判断呢,就是用哈希表查找这个数前面一个数是否存在,即num-1在序列中是否存在。存在那这个数肯定不是开头,直接跳过。
// 因此只需要对每个开头的数进行循环,直到这个序列不再连续,因此复杂度是O(n)。
// 以题解中的序列举例:
// [100,4,200,1,3,4,2]
// 去重后的哈希序列为:
// [100,4,200,1,3,2]
// 按照上面逻辑进行判断:
// 元素100是开头,因为没有99,且以100开头的序列长度为1
// 元素4不是开头,因为有3存在,过,
// 元素200是开头,因为没有199,且以200开头的序列长度为1
// 元素1是开头,因为没有0,且以1开头的序列长度为4,因为依次累加,2,3,4都存在。
// 元素3不是开头,因为2存在,过,
// 元素2不是开头,因为1存在,过。

//只需要一个set

unordered_set<int> s;

 for(int i=0;i<nums.size();++i) s.insert(nums[i]);
 int v=0;
for(auto t:s)
{
   if(!s.count(t-1)) {
    int u=1;
    int a=t;
    while(s.count(a+1))
        {
            ++u;
            a++;
        }
        v=max(v,u);

}

}

return v;




    }
};



题4---移动0

挺简单的题,唯一问题是需要注意语法,也就是数组越界问题,访问数组严格不能越界

  while(j<n&&nums[j]==0)

  {

    ++j;

    }

必须保证访问nums[j]的时候j一定没越界,否则直接全错

class Solution {
public:
    void moveZeroes(vector<int>& nums) {
        //我的想法是双指针,一个找0,一个找非0(最左边的)
//从第一个0的位置开始,j找到右边第一个数字,然后和这个0交换,i往右边遍历继续找第一个0
//此时第一个0的位置一定在j上或者j前面,然后j往后走继续找数字,这样就能保证两个指针都是往后走
//数字的顺序不会变
int n=nums.size();
int i=0;
while(i<n&&nums[i]!=0)++i;
if(i>=n)return;

int j=i;


while(j<n)
{
  while(j<n&&nums[j]==0)
  {
    ++j;
    } 
  if(j>=n)return ;

  swap(nums[i],nums[j]);
  while(i<n&&nums[i]!=0)++i;


}




    }
};

题5--盛最多水的容器

本质上是贪心,所以比较难解释

最大水量=Math.min(height[left],height[right])*长度,往中间移动长度一定会变短

如果移动高的那一边,会有两种情况:

1、下一根柱子的高度比现在高,高度还取最小值低的那边,最大水量比原来小

2、下一根柱子的高度比现在低,高度比原来的最小值还小,最大水量比原来小

如果移动低的那一边,会有两种情况:

1、下一根柱子的高度比现在高,高度就可以取更高的值,最大水量不一定比原来小

2、下一根柱子的高度比现在低,高度比原来的最小值还小,最大水量比原来小

class Solution {
public:
    int maxArea(vector<int>& height) {
        
//对于左边界,右边的比他矮的垂线都可以排除,无法威胁到他
//对于右边界,左边比他矮的也可以排除
//如果暴力,复杂度是n方
//题解思路
//答案来自于两个边界里,长度最短的一个垂线和这两个边界的距离
//所以如何确定左右边界呢,一开始我们让左右边界的距离最大
//这个时候决定因素就是短的那一边,此时移动长的那一边毫无意义,只有移动短的才可能得到更大的值
//相当于是一开始我选择最大边界,在这个基础上,我朝着可能变得更大的方向上探索

int i=0,j=height.size()-1;
int m=(j-i)*min(height[i],height[j]);

while(i<j)
{
if(height[i]<height[j])i++;
else j--;

m=max(m,(j-i)*min(height[i],height[j]));


}


return m;


    }
};

题6--三数之和

class Solution {
public:
    vector<vector<int>> threeSum(vector<int>& nums) {
        
        //为了不重复,我们可以先将数组排序
        //我们需要在排序后的数组中选出三个数字,满足相加为0
        //此时还有重复的可能,比如数组为0 0 0 0
        //所以在for循环时,无论是外层循环还是内层循环,下一个数如果和上一个相等就跳过
        //不需要三层for循环,当第一个数确定时,剩下两个数因为数组已经排好序,相当于
        //在有序数组里求两数之和,由于第一个数从前往后遍历,所以不会重复,列举出的数列都是递增数列
        sort(nums.begin(),nums.end());
        vector<vector<int>> v;
        for(int i=0;i<nums.size()-2;i++)
        {
           if(i>=1&&nums[i]==nums[i-1]) continue;
           
           int k=nums.size()-1;
           for(int j=i+1;j<nums.size()-1;j++)
           {    
                if(j>=i+2&&nums[j]==nums[j-1])continue ;
                while(k>j&&nums[j]+nums[k]>(0-nums[i]))k--;
                 if(k>j&&nums[j]+nums[k]==(0-nums[i]))
                 {
                    v.push_back({nums[i],nums[j],nums[k]});
                 }
                 
           }


        }


return v;




    }
};

官方题解:

差不多,但有break 很重要的是if里要一直判断 j<k

class Solution {
public:
    vector<vector<int>> threeSum(vector<int>& nums) {
        
        //为了不重复,我们可以先将数组排序
        //我们需要在排序后的数组中选出三个数字,满足相加为0
        //此时还有重复的可能,比如数组为0 0 0 0
        //所以在for循环时,无论是外层循环还是内层循环,下一个数如果和上一个相等就跳过
        //不需要三层for循环,当第一个数确定时,剩下两个数因为数组已经排好序,相当于
        //在有序数组里求两数之和,由于第一个数从前往后遍历,所以不会重复,列举出的数列都是递增数列
        sort(nums.begin(),nums.end());
        vector<vector<int>> v;
        for(int i=0;i<nums.size()-2;++i)
        {
           if(i>0&&nums[i]==nums[i-1]) continue;
           
           int k=nums.size()-1;
           for(int j=i+1;j<nums.size()-1;++j)
           {    
                if(j>i+1&&nums[j]==nums[j-1])continue ;
                while(k>j&&nums[j]+nums[k]>(0-nums[i]))--k;
                if(j==k)break;
                 if(k>j&&nums[j]+nums[k]==(0-nums[i]))
                 {
                    v.push_back({nums[i],nums[j],nums[k]});
                 }
                 
           }


        }


return v;



    }
};

题7--接雨水

困难题,先跳过

详解滑动窗口

首先复习一下滑动窗口(滑动窗口最大值那道题本质上不是个滑动窗口的题目)

题目列表:算法思想总结:滑动窗口算法_滑窗算法-CSDN博客

视频(讲的非常好):【掌握滑动窗口本质,秒杀相关题型】https://www.bilibili.com/video/BV1GAV7zHEWD?vd_source=5ee68676a0e9e18690592f6c4e3cff49

本质就是边遍历边剪枝

也就是说,对于一个数组或者一个串,我们如果暴力枚举,需要依次遍历所有字串,然后再判断满不满足条件,这个复杂度大约在三次方

对于一个长度为7的串,所有子串如下

我们不必遍历所有子串然后判断,可以边遍历边剪枝,具体来说就是

以上题为例子,当 (0,2)没有重复时,(1,2)(2,2)都没有重复(小于0,2的长度)

当(0,3)有重复时 (0,4)(0,5)(0,6)(0,7)都有重复,这些都可以不用判断

基于上面的思想,我们可以得到一个滑动窗口的模板

在这个模板的基础上,我们对下面几个题型进行解析

无重复字符的最长子串长度

长度最小的子数组

乘积小于k的子数组 

字符串中所有的字母异位词 

最小覆盖子串

题8--无重复字符的最长子串

class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        
    unordered_map<char,int> m;

int ans=0;
    for(int right=0,left=0;right<s.size();right++)
    {
       m[s[right]]++;
    
           while(m[s[right]]>1)//加入当前字母后发现哈希表中字母数大于1,说明当前字母就是重复字母
           {
              m[s[left]]--;
              left++;
           }

   ans=max(ans,right-left+1);




    }



return ans;






    }
};

题9--找到字符串中所有的字母异位词

class Solution {
public:
    vector<int> findAnagrams(string s, string p) {
        unordered_map<char,int> m;
        for(auto t:p)
        {
            m[t]++;
        }
vector<int> v;
  for(int right=0,left=0;right<s.size();right++)
  {
     m[s[right]]--;
     while(m[s[right]]<0)
     {
     m[s[left]]++;
     left++;

     }

if(right-left+1==p.size())
{
    v.push_back(left);
}



  }

return v;

    }
};

题10--和为k的子数组

前缀和加哈希表(两数之和)

前缀和明天抽空复习

题12--最小覆盖子串

class Solution {
public:
    string minWindow(string s, string t) {
        
        unordered_map<char,int> m;
        for(auto c:t)
        {
            m[c]++;
        }

    int u=0;
    string ans="";
   int  a=s.size();
   int start=-1,end=-1;
    for(int right=0,left=0;right<s.size();right++)
    {
       m[s[right]]--;
       if(m[s[right]]>=0)
       {
        u++;
       }

       if(u==t.size())
       {

        while(u==t.size())
        {
                                if(a>(right-left+1)||a==(right-left+1))
                                        {
                                            a=right-left+1;
                                            start=left;
                                            end=right;
                                        }
       m[s[left]]++;
       if(m[s[left]]>0) u--;
       left++;

        }



       }



    }

if(start==-1&&end==-1) return  ans;
else return s.substr(start,end-start+1);







    }
};

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

FastMCP:为大语言模型构建强大的上下文和工具服务

FastMCP&#xff1a;为大语言模型构建强大的上下文和工具服务 在人工智能快速发展的今天&#xff0c;大语言模型&#xff08;LLM&#xff09;已经成为许多应用的核心。然而&#xff0c;如何让这些模型更好地与外部世界交互&#xff0c;获取实时信息&#xff0c;执行特定任务&am…

数据结构(3)线性表-链表-单链表

我们学习过顺序表时&#xff0c;一旦对头部或中间的数据进行处理&#xff0c;由于物理结构的连续性&#xff0c;为了不覆盖&#xff0c;都得移&#xff0c;就导致时间复杂度为O&#xff08;n&#xff09;&#xff0c;还有一个潜在的问题就是扩容&#xff0c;假如我们扩容前是10…

Java Solon v3.3.0 发布(国产优秀应用开发基座)

Solon 框架&#xff01; Solon 是新一代&#xff0c;Java 企业级应用开发框架。从零开始构建&#xff08;No Java-EE&#xff09;&#xff0c;有灵活的接口规范与开放生态。采用商用友好的 Apache 2.0 开源协议&#xff0c;是“杭州无耳科技有限公司”开源的根级项目&#xff…

23种设计模式概述详述(C#代码示例)

文章目录 1. 引言1.1 设计模式的价值1.2 设计模式的分类 2. 面向对象设计原则2.1 单一职责原则 (SRP)2.2 开放封闭原则 (OCP)2.3 里氏替换原则 (LSP)2.4 接口隔离原则 (ISP)2.5 依赖倒置原则 (DIP)2.6 合成复用原则 (CRP)2.7 迪米特法则 (LoD) 3. 创建型设计模式3.1 单例模式 (…

数字化工厂升级引擎:Modbus TCP转Profinet网关助力打造柔性生产系统

在当今的工业自动化领域&#xff0c;通信协议扮演着至关重要的角色。Modbus TCP和Profinet是两种广泛使用的工业通信协议&#xff0c;它们分别在不同的应用场景中发挥着重要作用。然而&#xff0c;有时我们可能需要将这两种协议进行转换&#xff0c;以实现不同设备之间的无缝通…

FPGA生成随机数的方法

FPGA生成随机数的方法&#xff0c;目前有以下几种: 1、震荡采样法 实现方式一&#xff1a;通过低频时钟作为D触发器的时钟输入端&#xff0c;高频时钟作为D触发器的数据输入端&#xff0c;使用高频采样低频&#xff0c;利用亚稳态输出随机数。 实现方式二&#xff1a;使用三个…

【Linux C/C++开发】轻量级关系型数据库SQLite开发(包含性能测试代码)

前言 之前的文件分享过基于内存的STL缓存、环形缓冲区&#xff0c;以及基于文件的队列缓存mqueue、hash存储、向量库annoy存储&#xff0c;这两种属于比较原始且高效的方式。 那么&#xff0c;有没有高级且高效的方式呢。有的&#xff0c;从数据角度上看&#xff0c;&#xff0…

记录算法笔记(2025.5.17)验证二叉搜索树

给你一个二叉树的根节点 root &#xff0c;判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义如下&#xff1a; 节点的左子树只包含 小于 当前节点的数。节点的右子树只包含 大于 当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。 示例 1&#xff1a; 输入&…

flutter编译时 设置jdk版本

先查看flutter使用的版本 flutter doctor -v设置flutter的jdk目录 flutter config --jdk-dir "E:\soft\android-studio\jbr" 然后再验证下&#xff0c;看是否设置成功

ctfshow——web入门254~258

目录 web入门254 web入门255 web入门256 web入门257 web入门258 反序列化 先来看看其他师傅的讲解 web入门254 源码&#xff1a; <?phperror_reporting(0); highlight_file(__FILE__); include(flag.php);class ctfShowUser{public $usernamexxxxxx;public $passwo…

【数据处理】xarray 数据处理教程:从入门到精通

目录 xarray 数据处理教程&#xff1a;从入门到精通一、简介**核心优势** 二、安装与导入1. 安装2. 导入库 三、数据结构&#xff08;一&#xff09;DataArray&#xff08;二&#xff09; Dataset&#xff08;三&#xff09;关键说明 四、数据操作&#xff08;一&#xff09;索…

qt5.14.2 opencv调用摄像头显示在label

ui界面添加一个Qlabel名字是默认的label 还有一个button名字是pushButton mainwindow.h #ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow> #include <opencv2/opencv.hpp> // 添加OpenCV头文件 #include <QTimer> // 添加定…

芯片生态链深度解析(三):芯片设计篇——数字文明的造物主战争

【开篇&#xff1a;设计——数字文明的“造物主战场”】 当英伟达的H100芯片以576TB/s显存带宽重构AI算力边界&#xff0c;当阿里平头哥倚天710以RISC-V架构实现性能对标ARM的突破&#xff0c;这场围绕芯片设计的全球竞赛早已超越技术本身&#xff0c;成为算法、架构与生态标准…

Rocky Linux 9.5 基于kubeadm部署k8s

一&#xff1a;部署说明 操作系统https://mirrors.aliyun.com/rockylinux/9.5/isos/x86_64/Rocky-9.5-x86_64-minimal.iso 主机名IP地址配置k8s- master192.168.1.1412颗CPU 4G内存 100G硬盘k8s- node-1192.168.1.1422颗CPU 4G内存 100G硬盘k8s- node-2192.168.1.1432…

uart16550详细说明

一、介绍 uart16550 ip core异步串行通信IP连接高性能的微控制器总线AXI,并为异步串行通信提供了 控制接口。软核设计连接了axilite接口。 二、特性 1.axilite接口用于寄存器访问和数据传输 2.16650串口和16450串口的软件和硬件寄存器都是兼容的 3.默认的core配置参数&#xf…

抢跑「中央计算+区域控制」市场,芯驰科技高端智控MCU“芯”升级

伴随着整车EE架构的加速变革&#xff0c;中国高端车规MCU正在迎来“新格局”。 在4月23日开幕的上海国际车展期间&#xff0c;芯驰科技面向新一代AI座舱推出了X10系列芯片&#xff0c;以及面向区域控制器、电驱和动力域控、高阶辅助驾驶和舱驾融合系统等的高端智控MCU产品E3系…

day015-进程管理

文章目录 1. 服务开机自启动2. 进程3. 僵尸进程3.1 处理僵尸进程3.2 查看僵尸进程3.2 排查与结束僵尸进程全流程 4. 孤儿进程5. 进程管理5.1 kill三剑客5.2 后台运行 6. 进程监控命令6.1 ps6.1.1 ps -ef6.1.2 ps aux6.1.3 VSZ、RSS6.1.4 进程状态6.1.5 进程、线程 6.2 top6.2.1…

POWER BI添加自定义字体

POWER BI添加自定义字体 POWER BI内置27种字体&#xff0c;今天分享一种很简单的添加自定义字体的方法。以更改如下pbix文件字体为例&#xff1a; 第一步&#xff1a;将该pbix文件重命名为zip文件并解压&#xff0c;找到主题json文件&#xff0c;如下图所示&#xff1a; 第二步…

协议不兼容?Profinet转Modbus TCP网关让恒压供水系统通信0障碍

在现代工业自动化领域中&#xff0c;通信协议扮演着至关重要的角色。ModbusTCP和Profinet是两种广泛使用的工业通信协议&#xff0c;它们各自在不同的应用场合中展现出独特的优势。本文将探讨如何通过开疆智能Profinet转Modbus TCP的网关&#xff0c;在恒压供水系统中实现高效的…

ChatGPT + DeepSeek 联合润色的 Prompt 模板指令合集,用来润色SCI论文太香了!

对于非英语母语的作者来说,写SCI论文的时候经常会碰到语法错误、表达不够专业、结构不清晰以及术语使用不准确等问题。传统的润色方式要么成本高、效率低,修改过程又耗时又费力。虽然AI工具可以帮助我们来润色论文,但单独用ChatGPT或DeepSeek都会存在内容泛泛、专业性不足的…