贪心算法—

 

        贪心算法是一种在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望导致结果是全局最好或最优的算法。这种算法并不总是能找到全局最优解,但在某些问题上能提供足够好的解决方案。贪心算法的关键特性包括:

  1. 局部最优选择:在每一步决策时,都选择当前看来最佳的解决方案,不考虑长远的影响。
  2. 无后效性:过去做出的选择不会影响未来的选择,也就是说,当前的最优选择不会因为之前做了什么选择而改变。
  3. 贪心选择性质:问题需要具备贪心选择性质,即局部最优能导致全局最优或者部分最优解。

贪心算法适用于以下类型的问题:

  • 最优装载问题:如背包问题的部分情况。
  • 最小生成树问题:如Prim算法和Kruskal算法。
  • 单源最短路径问题:如Dijkstra算法(非负权重时)。
  • 活动安排问题:选择最多的互不冲突的活动。

例题:

 860. 柠檬水找零 - 力扣(LeetCode)

class Solution {
public:
    bool lemonadeChange(vector<int>& bills) {
        int val_5=0; int val_10=0;
        for(int &val:bills){
            if(val==5){
                val_5++;
            }else if(val==10){
                val_10++;
                val_5--;
            }else if(val==20){
                if(val_10>0){
                    val_10--;
                    val_5--;
                }else{
                    val_5-=3;
                }
            }
            if(val_5<0||val_10<0){
                return false;
            }
        }
        return true;
    }
};

2208. 将数组和减半的最少操作次数 - 力扣(LeetCode)

class Solution {
public:
    int halveArray(vector<int>& nums) {
        priority_queue<double> heap;//val/2很可能为小数
        double sum=0;//**1**使用 int,会导致sum/2,导致sum结尾
        for(int& val:nums){
            heap.push(val);
            sum+=val;
        }
        int count=0;
        sum/=2.0;
        while(sum>0){//sum<=为结束条件,while和for需要运行条件,
            double tmp=heap.top()/2.0;
            heap.pop();
            sum-=tmp;
            heap.push(tmp);
            count++;
        }
        return count;
    }
};

179. 最大数 - 力扣(LeetCode)

class Solution {
public:
    string largestNumber(vector<int>& nums) {
        vector<string> strs;
        for(int &val:nums) strs.push_back(to_string(val));

        sort(strs.begin(),strs.end(),[](const string &s1,const string &s2){
            return s1+s2>s2+s1;//"=" 不行,无法处理,导致string溢出
        });
        
        string ret="";
        for(string &s1:strs) ret+=s1;
        cout<<ret<<endl;
        //处理前导零:
        if(ret[0]=='0') return "0";
        return ret;
    }
};

376. 摆动序列 - 力扣(LeetCode)

class Solution {
public:
    int wiggleMaxLength(vector<int>& nums) {
        int n=nums.size();
        //if(n<2) return n;//**4**,初始化,其实n=0或者n=1不用特殊处理
        int right=0,left=0;//**3**,初始化为0:统计初始结点。
        int ret=0;
        for(int i=0;i<n-1;i++){
            right=nums[i+1]-nums[i];//**2**采用趋势记录,来判断波峰,波谷
            if(right==0) continue;//***1**:跳过没有上升和下降的区间
            if(right*left<=0) ret++;//**3**:“=”是为了将起始结点统计进ret;
            
            left=right;
        }

        return ret+1;
    }
};

300. 最长递增子序列 - 力扣(LeetCode)

class Solution {
public:
    int lengthOfLIS(vector<int>& nums) {
        int n=nums.size();
        vector<int> ret;
        ret.push_back(nums[0]);
        for(int i=1;i<n;i++){
            if(nums[i]>ret.back()){
                ret.push_back(nums[i]);
            }else{
                int left=0; int right=ret.size()-1;
                while(left<right){
                    int mid=left+(right-left)/2;//**1**,右区间的左端点,由于是左端点,所以right-left不用再+1,例如:[2,2],取左边的2,如果+1,取右边的2,错误
                    if(ret[mid]<nums[i]) left=mid+1;
                    else right=mid;
                }
                ret[left]=nums[i];
            }
        }
        return ret.size();
    }
};

334. 递增的三元子序列 - 力扣(LeetCode)

class Solution {
public:
    bool increasingTriplet(vector<int>& nums) {
        int n=nums.size();
        vector<int> ret;
        ret.push_back(nums[0]);

        for(int i=1;i<n;i++){
            if(nums[i]>ret.back()){
                ret.push_back(nums[i]);
            }else{
                int left=0; int right=ret.size()-1;
                while(left<right){
                    int mid=left+(right-left)/2;
                    if(ret[mid]<nums[i]) left=mid+1;
                    else right=mid;
                }
                ret[left]=nums[i];
            }
            if(ret.size()>=3) return true;
        }
        return false;
    }
};

674. 最长连续递增序列 - 力扣(LeetCode)

class Solution {
public:
    int findLengthOfLCIS(vector<int>& nums) {
        int ret=1;
        int n=nums.size();
        int begin=0;int end=0;
        while(begin<n){
            end=begin+1;
            while(end<n&&nums[end]>nums[end-1]){
                ret=max(ret, end-begin+1);
                cout<<"begin,end"<<begin<<" "<<end<<endl;
                end++;//**1**满足条件后更新结果,循环条件的值应该在后面++
            }
            begin=end;
        }
        return ret;
    }
};

121. 买卖股票的最佳时机 - 力扣(LeetCode)

class Solution {
public:
    int maxProfit(vector<int>& prices) {
        int n=prices.size();
        int _min=prices[0];
        int ret_maxprofit=0;
        for(int i=1;i<n;i++){
            ret_maxprofit=max(ret_maxprofit,prices[i]-_min);
            _min=min(_min,prices[i]);
        }
        return ret_maxprofit;
    }
};

122. 买卖股票的最佳时机 II - 力扣(LeetCode)

class Solution {
public:
    int maxProfit(vector<int>& prices) {
        int n=prices.size();
        int ret=0;
        int begin=0; int end=0;
        while(begin<n){
            end=begin+1;
            int tmp=0;
            while(end<n&&prices[end]>prices[end-1]){
                tmp=max(tmp,prices[end]-prices[begin]);
                end++;
            }
            ret+=tmp;
            begin=end;
        }
        return ret;
    }
};

1005. K 次取反后最大化的数组和 - 力扣(LeetCode)

class Solution {
    struct Greater{
        bool operator()(int &a,int &b){//operator,运算符重载,一定记得加运算符,尤其是()
            return a>b;
        }
    };
public:
    int largestSumAfterKNegations(vector<int>& nums, int k) {
        // Greater Greater_1;
        priority_queue<int,vector<int>,Greater> q;
        int sum=0;
        for(int &val:nums){
            q.push(val);
            sum+=val;
        }
        while(k){
            if(q.top()<0){
                int tmp=-q.top();
                sum+=2*tmp;
                q.pop();
                q.push(tmp);
            }else{
                if(k%2==0){
                    return sum;
                }else{
                    return sum-2*q.top();
                }
            }
            k--;
        }
        return sum;
    }
};

2418. 按身高排序 - 力扣(LeetCode)

class Solution {
public:
    vector<string> sortPeople(vector<string>& names, vector<int>& heights) {
        int n=names.size();
        vector<int> v1;
        for(int i=0;i<n;i++){
            v1.push_back(i);
        }
        sort(v1.begin(),v1.end(),[&](int i,int j){//**1**[&]:引用上层代码块的变量
            return heights[i]>heights[j];
        });

        vector<string> ret;
        for(int &i:v1){
            ret.push_back(names[i]);
        }
        return ret;
    }
};

870. 优势洗牌 - 力扣(LeetCode)

class Solution {
public:
    vector<int> advantageCount(vector<int>& nums1, vector<int>& nums2) {
        int n=nums1.size();
        sort(nums1.begin(),nums1.end());
        vector<int> index;
        for(int i=0;i<n;i++) index.push_back(i);
        sort(index.begin(),index.end(),[&](int i,int j){
            return nums2[i]<nums2[j];
        });
        //田忌赛马
        vector<int> ret(n);
        int left=0; int right=n-1;
        for(int &x:nums1){
            if(x>nums2[index[left]]) ret[index[left++]]=x;//**1**ret下标与nums2中对应好
            else ret[index[right--]]=x;
        }
        return ret;
    }
};

409. 最长回文串 - 力扣(LeetCode)

class Solution {
public:
    int longestPalindrome(string s) {
        int vis[128]={0};
        for(char &ch:s){
            vis[ch]++;
        }
        int ret=0;//**1**记得初始化。
        int flag=0;//回文串最中间的那个数可以为单个
        for(int i=0;i<128;i++){
            if(vis[i]%2==0){
                ret+=vis[i];
            }else if(vis[i]%2==1){
                ret+=vis[i]-1;
                flag=1;
            }
        }
    
        return flag==1?ret+1:ret;
    }
};

942. 增减字符串匹配 - 力扣(LeetCode)

class Solution {
public:
    vector<int> diStringMatch(string s) {
        int left=0; int right=s.size();
        vector<int> ret;
        for(char &ch:s){
            if(ch=='I')  ret.push_back(left++);
            else  ret.push_back(right--);
        }
        ret.push_back(left);
        return ret;
    }
};

455. 分发饼干 - 力扣(LeetCode)

class Solution {
public:
    int findContentChildren(vector<int>& g, vector<int>& s) {
        sort(g.begin(),g.end());
        sort(s.begin(),s.end());
        int left=0; int right=g.size()-1;
        int n=s.size();
        int ret=0;
        for(int i=0;i<n&&left<=right;i++){//**1**防止g下标溢出
            if(s[i]>=g[left]) {
                ret++;
                left++;
            }
        }
        return ret;
    }
};

553. 最优除法 - 力扣(LeetCode)

class Solution {
public:
    string optimalDivision(vector<int>& nums) {
        int n=nums.size();//策略: 看出分式,1:第一个数字一定在分子,第二个数必在分母 2:所以将分母变最小或将分子变最大,则两个是同一个操作,A/(B/C):将分母变小,==A*C/B:将分子变大
        if(n==0) return 0;
        else if(n==1){
            return to_string(nums[0]);
        }else if(n==2){
            return to_string(nums[0])+'/'+to_string(nums[1]);
        }
        string ret=to_string(nums[0])+"/("+to_string(nums[1]);
        for(int i=2;i<n;i++){
            ret+="/"+to_string(nums[i]);
        }
        ret+=")";
        return ret;
    }   
};

45. 跳跃游戏 II - 力扣(LeetCode)

class Solution {
public:
    int jump(vector<int>& nums) {
        int left=0; int right=0; int maxpos=0; int n=nums.size(); int ret=0;
        while(left<=right){//循环条件,与left=right+1组合,判断是否不能够跳跃到下标n-1
            if(maxpos>=n-1) return ret;//**1**maxpos表示最大能跳跃的position,所以>=n-1
            
            for(int i=left;i<=right;i++){
                maxpos=max(maxpos,nums[i]+i);//**2**nums[left]+left:表示跳跃的最大距离
            }
            left=right+1;
            right=maxpos;
            ret++;//表示一次
        }
        return -1;
    }
};

55. 跳跃游戏 - 力扣(LeetCode)

class Solution {
public:
    bool canJump(vector<int>& nums) {
        int left=0; int right=0; int maxpos=0;
        while(left<=right){
            if(maxpos>= nums.size()-1) return true;
            for(int i=left;i<=right;i++){
                maxpos=max(maxpos,nums[i]+i);
            }
            left=right+1;
            right=maxpos;
        }
        return false;
    }
};

134. 加油站 - 力扣(LeetCode)

class Solution {
public:
    int canCompleteCircuit(vector<int>& gas, vector<int>& cost) {
        int n=gas.size();
        for(int i=0;i<n;i++){
            int rest=0;//标记剩余汽油
            int step=0;
            for(;step<n;step++){
                int index=(i+step)%n;
                rest+=gas[index]-cost[index];
                if(rest<0) break;//index无法到达index+1
            }            
            if(step==n) return i;
            i=i+step;
        }
        return -1;
    }
};

738. 单调递增的数字 - 力扣(LeetCode)

class Solution {
public:
    int monotoneIncreasingDigits(int n) {//算法:找到最高并且递增的下标i,将s[i]--,其余低位变9
        string s=to_string(n);
        int m=s.size();
        int i=0;
        while(i<m-1&&s[i]<=s[i+1]) i++;   
        if(i==m-1)  return n;//特殊情况
        while(i-1>=0&&s[i-1]==s[i]) i--;
        s[i]--;
        for(int j=i+1;j<m;j++) s[j]='9';
        return stoi(s);
    }
};

991. 坏了的计算器 - 力扣(LeetCode)

class Solution {
public:
    int brokenCalc(int startValue, int target) {//正难则反:利用本题中target为偶数时,选择%2最优,仅奇数时,才+1
        int ret=0;
        while(target>startValue){
            if(target%2==0) target/=2;
            else target++;
            ret++;
        }
        return ret+startValue-target;//startValue-target:表示target小于startValue时,所需的次数
    }
};

56. 合并区间 - 力扣(LeetCode)

class Solution {
public:
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        sort(intervals.begin(),intervals.end(),[](vector<int> a,vector<int> b){
            return a[0]<b[0];//不能等于,会判错,对于快排来说,没有稳定性,不用<=,a[0]<=b[0]会出错:显示vector访问越界,没有值就访问。
        });
        int n=intervals.size();
        vector<vector<int>> ret;
        int left=intervals[0][0]; int right=intervals[0][1];
        for(int i=1;i<n;i++){
            if(intervals[i][0]<=right){
                right=max(right,intervals[i][1]);
            }else{
                ret.push_back({left,right});
                left=intervals[i][0]; right=intervals[i][1];
            }            
        }
        ret.push_back({left,right});
        return ret;
    }
};

435. 无重叠区间 - 力扣(LeetCode)

class Solution {
public:
    int eraseOverlapIntervals(vector<vector<int>>& intervals) {
        sort(intervals.begin(),intervals.end());
        int n=intervals.size();
        int ret=0;
        int left=intervals[0][0]; int right=intervals[0][1];
        for(int i=1;i<n;i++){
            int a=intervals[i][0]; int b=intervals[i][1];
            if(a<right){//找出重合中最大的区间。
                ret++;
                //int right=min(right,b);**1**从新定义错误,上面判断的a<right
                //的right是上面的域的right
                right=min(right,b);
            }else{
                left=a; right=b;
            }   
        }
        return ret;
    }
};

452. 用最少数量的箭引爆气球 - 力扣(LeetCode)

class Solution {
public:
    int findMinArrowShots(vector<vector<int>>& points) {
        sort(points.begin(),points.end());
        int n=points.size();
        int left=points[0][0]; int right=points[0][1];
        int ret=0;
        for(int i=1;i<n;i++){
            int a=points[i][0]; int b=points[i][1];
            if(a<=right){
                right=min(b,right);
            }else{
                left=a; right=b;
                ret++;
            }
        }    
        return ret+1;
    }
};

397. 整数替换 - 力扣(LeetCode)

class Solution {
public:
    int integerReplacement(long long n) {
        int ret=0;
        while(n>1){
            if(n%2==0){
                n/=2;
                ret++;
            }else{
                if(n==3){//特例
                    ret+=2;
                    n=1;
                }
                else if(n%4==3){
                    n+=1;
                    ret++;
                }else if(n%4==1){
                    n-=1;
                    ret++;
                }
            }
        }
        return ret;
    }
};

354. 俄罗斯套娃信封问题 - 力扣(LeetCode)

class Solution {
public:
    int maxEnvelopes(vector<vector<int>>& envelopes) {
        sort(envelopes.begin(),envelopes.end(),[](vector<int> &a,vector<int> &b){
            return a[0]!=b[0]?a[0]<b[0]:a[1]>b[1];//必须降序,不降序的话,后面求最长递增子序列时,a[0]==b[0],a[1]>b[1],会被纳入序列中
        });
        int n=envelopes.size();
        vector<int> ret;
        ret.push_back(envelopes[0][1]);//ret;表示小标+1的长度的单调递增子序列的末尾最小数是什么。
        for(int i=1;i<n;i++){
            int b=envelopes[i][1];
            if(b>ret.back()){
                ret.push_back(b);
            }else{
                int left=0, right=ret.size();
                while(left<right){
                    int mid=left+(right-left)/2;//二分求左区间的最小结点。左区间:>=target.
                    if(ret[mid]<b){
                        left=mid+1;
                    }else{
                        right=mid;
                    }
                }
                ret[left]=b;
            }
        }
        return ret.size();
    }
};

1262. 可被三整除的最大和 - 力扣(LeetCode)

class Solution {
public:
    int maxSumDivThree(vector<int>& nums) {
        int sum=0;
        //最小
        int INF=0x3f3f3f3f;
        int x1=INF; int x2=INF;
        int y1=INF; int y2=y1;
        for(int &val:nums){
            sum+=val;
            if(val%3==1){
                // int tmp=x1;//取最小值无法判断val在x1和x2之间
                // x1=min(val,x1);
                // if(x1==val) x2=tmp;
                if(val<x1) {
                    x2=x1; x1=val; 
                }else if(val<x2){
                    x2=val;
                }
            }
            if(val%3==2){
                if(val<y1) {
                    y2=y1; y1=val; 
                }else if(val<y2){
                    y2=val;
                }
            }
        }
        if(sum%3==0) return sum;
        else if(sum%3==2) return sum-min(y1,x1+x2);//超出int,两种情况二选一,其中有的情况不存在比如样例1中x1和x2不存在,但是应为是求最小值,初始化为INT_MAX不会被选取,但是相加会越界
        else if(sum%3==1) return sum-min(x1,y1+y2);
        return sum;
    }
};

1054. 距离相等的条形码 - 力扣(LeetCode)

class Solution {
public:
    vector<int> rearrangeBarcodes(vector<int>& barcodes) {
        int n=barcodes.size();
        unordered_map<int,int> hash;
        int maxval=0;int maxcount=0;
        for(int x:barcodes){
            if(maxcount<++hash[x]){
                maxcount=hash[x];
                maxval=x;
            }
        }
        vector<int> ret(n,0);
        int index=0;
        for(int i=0;i<maxcount;i++){
            ret[index]=maxval;
            index+=2;
        }
        hash.erase(maxval);
        //index%=n;//**1**仅仅对n=奇数有效
        for(auto& [x,count]:hash){
            for(int i=0;i<count;i++){
                if(index>=n) index=1;
                ret[index]=x;
                index+=2;
            }
        }
        return ret;
    }
};

767. 重构字符串 - 力扣(LeetCode)

class Solution {
public:
    string reorganizeString(string s) {
        unordered_map<int,int> hash;
        char max_ch=0; int max_count=0;
        for(char& ch:s){
            if(max_count<++hash[ch]){
                max_count=hash[ch];
                max_ch=ch;
            }
        }
        if(max_count>(s.size()+1)/2) return "";
        int n=s.size();
        string ret;
        ret.resize(n);
        int index=0;
        for(int i=0;i<max_count;i++){
            ret[index]=max_ch;
            index+=2;
        }
        hash.erase(max_ch);
        for(auto& [x,count]:hash){
            for(int i=0;i<count;i++){
                if(index>=n) index=1;                
                ret[index]=x;
                index+=2;
            }
        }
        return ret;
    }
};

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

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

相关文章

【TB作品】MSP430G2553单片机,转速测量系统,转速测量仪,霍尔传感器

文章目录 题目器件原理霍尔传感器测速原理&#xff1a;电机如何调节速度程序设计 实验报告实验题目实验目的实验器材实验原理霍尔传感器测速原理电机调速原理定时器中断原理 硬件连接软件设计定时器配置主程序中断处理程序 实验结果实验总结 题目 设计基于MSP430的转速测量仪的…

动手学深度学习(Pytorch版)代码实践 -深度学习基础-10权重衰减

10权重衰减 """ 正则化是处理过拟合的常用方法&#xff1a;在训练集的损失函数中加入惩罚项&#xff0c;以降低学习到的模型的复杂度。 保持模型简单的一个特别的选择是使用L2惩罚的权重衰减。这会导致学习算法更新步骤中的权重衰减。 """impor…

Python基础教程(三十):math模块

&#x1f49d;&#x1f49d;&#x1f49d;首先&#xff0c;欢迎各位来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里不仅可以有所收获&#xff0c;同时也能感受到一份轻松欢乐的氛围&#xff0c;祝你生活愉快&#xff01; &#x1f49d;&#x1f49…

AudioSep:从音频中分离出特定声音(人声、笑声、噪音、乐器等)本地一键整合包下载

AudioSep是一种 AI 模型&#xff0c;可以使用自然语言查询进行声音分离。这一创新性的模型由Audio-AGI开发&#xff0c;使用户能够通过简单的语言描述来分离各种声音源。 比如在嘈杂的人流车流中说话的录音中&#xff0c;可以分别提取干净的人声说话声音和嘈杂的人流车流噪声。…

对于初学者,该如何选择大模型框架 LlamaIndex 与 LangChain ?

节前&#xff0c;我们星球组织了一场算法岗技术&面试讨论会&#xff0c;邀请了一些互联网大厂朋友、参加社招和校招面试的同学. 针对算法岗技术趋势、大模型落地项目经验分享、新手如何入门算法岗、该如何准备、面试常考点分享等热门话题进行了深入的讨论。 汇总合集&…

任务3.8.4 利用RDD实现分组排行榜

文章目录 1. 任务说明2. 解决思路3. 准备成绩文件4. 采用交互式实现5. 采用Spark项目实战概述&#xff1a;使用Spark RDD实现分组排行榜任务背景任务目标技术选型实现步骤1. 准备数据2. 数据上传至HDFS3. 启动Spark Shell4. 读取数据生成RDD5. 数据处理6. 计算TopN7. 输出结果8…

「动态规划」如何求最长湍流子数组的长度?

78. 最长湍流子数组https://leetcode.cn/problems/longest-turbulent-subarray/description/ 给定一个整数数组arr&#xff0c;返回arr的最长湍流子数组的长度。如果比较符号在子数组中的每个相邻元素对之间翻转&#xff0c;则该子数组是湍流子数组。更正式地来说&#xff0c;…

算法期末整理

目录 一 算法概述 二 递归与分治策略 三 动态规划 四 贪心算法 五 回溯法 六 分支限界法 七 随机化算法 八 线性规划与网络流 一 算法概述 算法的概念 通俗地讲&#xff0c;算法是指解决问题的一种方法或一个过程。更严格地讲&#xff0c;算法是由若干条指令组成的有穷…

设计模式——职责链模式

职责链模式(Chain of Responsibility) 使多个对象都有机会处理请求&#xff0c;从而避免请求的发送者和接收者之间的耦合关系。将这个对象连接成一条链&#xff0c;并沿着这条链传递请求&#xff0c;直到有一个对象处理它为止。   发出请求的客户端并不知道职责链中哪一个对象…

python watchdog 配置文件热更新

目录 一、Watchdog示例 二、aiohttp服务配置热更新 在同事的golang代码中学习到了config.json热更新的功能&#xff0c;这里自己也学习了一下python写web服务的时候怎么来实现配置的热更新。主要是利用Watchdog这个第三方python库&#xff0c;来监控文件系统的改变&#xff0…

实战电商大数据项目搭建||电商大数据采集||电商API接口

我会提供给你大概1亿条真实的互联网用户上网数据&#xff0c;至于来源&#xff0c;我先不告诉你&#xff0c;绝对是你在网络上无法找到的宝贵数据源。 此外&#xff0c;还会给你提供一个基于当前数据特点而设计的大数据处理方案。 当然&#xff0c;为了防止用户的隐私部分被泄露…

每日优秀影视分享❗❗

一、热门电影推荐 《头脑特工队 2》&#xff1a;皮克斯再次为观众带来了这部经典动画的续集。 影片讲述了刚步入青春期的小女孩莱莉脑海中的复杂情绪进行的一场奇妙冒险。 这部电影不仅延续了前作的优秀品质&#xff0c;更在情感深度和视觉呈现上有了进一步的提升。 《艾尔登…

同时使用接口文档swagger和knife4j

项目场景&#xff1a; springboot项目中同时使用接口文档swagger和knife4j 问题描述 在实体类中设置了字段必填的属性&#xff0c;在访问接口文档时出现异常 实体类关键代码片段 /*** 部门表 sys_dept*/ public class SysDept extends BaseEntity {private static final lo…

Python基础入门

目录 1. 什么是Python&#xff1f; 2. 安装Python 3. Python基础语法 4. 数据结构 5. 文件操作 6. Python标准库 总结 1. 什么是Python&#xff1f; Python是一种高级编程语言&#xff0c;由Guido van Rossum于1991年发布。它以其简单易读的语法和强大的功能而闻名&…

高效22KW双向DCDC储能、充电电源模块项目设计开发

22kW 双向CLL谐振变换器的目标是输出电压范围宽、高效率和高功率密度的双向应用&#xff0c;如电动汽车车载充电器和储能系统。研究了一种新的灵活的 CLLC 双向谐振变换器增益控制方案&#xff0c;以便在充放电模式下实现高效率和宽电压增益范围。得益于 Wolfspeed C3MTM 1200V…

读《文明之光》第2册总结

《文明之光》系列大致按照从地球诞生到近现代的顺序讲述了人类文明进程的各个阶段&#xff0c;每个章节相对独立&#xff0c;全景式地展现了人类文明发展历程中的多样性。《文明之光》系列第二册讲述了从近代科学兴起&#xff0c;到工业革命时代&#xff0c;以及原子能应用这一…

【代码随想录】【算法训练营】【第46天】 [121]买卖股票的最佳时机 [122]买卖股票的最佳时机II [123]买卖股票的最佳时机III

前言 思路及算法思维&#xff0c;指路 代码随想录。 题目来自 LeetCode。 day 46&#xff0c;周六&#xff0c;坚持很困难~ 题目详情 [121] 买卖股票的最佳时机 题目描述 121 买卖股票的最佳时机 解题思路 前提&#xff1a; 思路&#xff1a; 重点&#xff1a; 代码实…

Springboot应用的信创适配

CentOS7在2024.6.30停止维护后&#xff0c;可替代的Linux操作系统-CSDN博客 全面国产化之路-信创-CSDN博客 信创适配评测-CSDN博客 Springboot应用的信创适配 Springboot应用的信创适配&#xff0c;如上图所示需要适配的很多&#xff0c;从硬件、操作系统、中间件&#xff08…

开启声音的奇幻之旅:AI声音变换器的魔法秘籍与创意应用

AI视频生成&#xff1a;小说文案智能分镜智能识别角色和场景批量Ai绘图自动配音添加音乐一键合成视频https://aitools.jurilu.com/这个充满科技魔力的时代&#xff0c;AI Voice Changer 就像一把神奇的钥匙&#xff0c;能为我们打开声音的魔法之门。今天&#xff0c;就让我带你…

基于CentOS Stream 9平台 安装/卸载 Redis7.0.15

已更正systemctl管理Redis服务问题 1. 官方下载地址 https://redis.io/downloads/#redis-downloads 1.1 下载或上传到/opt/coisini目录下&#xff1a; mkdir /opt/coisini cd /opt/coisini wget https://download.redis.io/releases/redis-7.0.15.tar.gz2. 解压 tar -zxvf re…