news 2026/6/12 20:28:58

算法期末复习1

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法期末复习1

实验1:递归算法

折线分割

关键在于 f(n)=f(n-1)+4*(n-1)+1

#include<iostream> using namespace std; int main(){ int num=10000; int *arr=new int[10000]; arr[0]=0; arr[1]=2; for(int i=2;i<=10000;i++){ arr[i]=arr[i-1]+4*(i-1)+1; } int n; cin>>n; while(n>0){ n--; int x; cin>>x; cout<<arr[x]<<endl; } }

骨牌铺方格

f(n)=f(n-1)+f(n-2) 用c++时 需要注意 溢出 数组应该用 long long

#include<iostream> using namespace std; int main(){ int x; long long *arr=new long long[51]; arr[0]=0; arr[1]=1; arr[2]=2; for(int i=3;i<=50;i++){ arr[i]=arr[i-1]+arr[i-2]; } while(cin>>x){ cout<<arr[x]<<endl; } }

排队问题

f(n)=f(n-1)+f(n-2)+f(n-4) 操~蛋的是 用cpp会溢出 需要 模拟大数运算 建议直接py

#py注意事项 for i in range(1,10) i 到不到 10 #不要忘记写最后的if import sys def main(): arr=[1,1,2,4,7] for i in range (5,1200): arr.append(arr[i-1]+arr[i-2]+arr[i-4]) for line in sys.stdin: line = line.strip() if not line: continue x=int(line) print(arr[x]) if __name__ == "__main__": main()

排错问题

f(n)=(n-1)(f(n-1)+f(n-2)) 使用long long 数组

#include<iostream> using namespace std; int main(){ long long *arr=new long long[21]; arr[0]=0; arr[1]=0; arr[2]=1; arr[3]=2; for(int i=4;i<=20;i++){ arr[i]=(i-1)*(arr[i-1]+arr[i-2]); } int x; while(cin>>x){ cout<<arr[x]<<endl; } }

最大字段和问题

用双指针 left=right=0 right走 当sum<0 left=right+1

#include<iostream> using namespace std; int main(){ int n; cin>>n; int put=0; while(n>0){ n--; put++; int len; cin>>len; int *arr=new int[len]; for(int i=0;i<len;i++){ cin>>arr[i]; } int max=arr[0]; int sum=0; int left=0; int right=0; int resl=0; int resr=0; while(right<len && left<len){ sum+=arr[right]; if(sum>max){ max=sum; resl=left; resr=right; } if(sum<0){ sum=0; left=right+1; } right++; } cout<<"Case "<<put<<":"<<endl; cout<<max<<" "<<resl+1<<" "<<resr+1<<endl; } }

作业 渐进界+递归方程+排序

主定理

差距几何

桶排序 算出平均差距 (考虑到可能为0 手动+1 扩大桶大小 可能出现问题 但这道题可以通过😀)

然后分n-1个桶 每个桶维护 一段范围数据的最大值和最小值 最后 比较相邻非空桶最大最小值之差

int fun ( int arr[],int n ){ if(n<2) return 0; int max=arr[0]; int min=arr[0]; for(int i=0;i<n;i++){ if(arr[i]>max){ max=arr[i]; } if(arr[i]<min){ min=arr[i]; } } int aver=(max-min)/n+1; int *minArr=(int *)malloc(sizeof(int)*(n-1)); int *maxArr=(int *)malloc(sizeof(int)*(n-1)); for(int i=0;i<n-1;i++){ minArr[i]=-1; maxArr[i]=-1; } for(int i=0;i<n;i++){ int num=(arr[i]-min)/aver; if(arr[i]==max){ num=n-2; } if(minArr[num]==-1){ minArr[num]=arr[i]; }else if(minArr[num]>arr[i]){ minArr[num]=arr[i]; } if(maxArr[num]==-1){ maxArr[num]=arr[i]; }else if(maxArr[num]<arr[i]){ maxArr[num]=arr[i]; } } int res=0; int pArr=0; for(int i=0;i<n-1;i++){ if(minArr[i]!=-1){ pArr=i; break; } } for(int i=pArr+1;i<n-1;i++){ if(minArr[i]==-1){ continue; }else{ if(res<minArr[i]-maxArr[pArr]){ res=minArr[i]-maxArr[pArr]; } pArr=i; } } return res; }

n以内素数个数

直接假定n范围在1e8 可以通过

#include<iostream> const int MAX=1e8; using namespace std; int main(){ bool *arr=new bool[ MAX]; for(int i=0;i< MAX;i++){ arr[i]=true; } for(int i=2;i< MAX;i++){ if(arr[i]==true){ int j=i+i; while(j< MAX){ arr[j]=false; j+=i; } } } int res=0; int x; cin>>x; for(int i=2;i<=x;i++){ if(arr[i]==true) res++; } cout<<res; }

快速排序

#include<iostream> using namespace std; void swap(int &a,int &b); int pfunc(int*arr,int start,int end); void quickSort(int *arr,int start,int end,int n); int main(){ int n; while(cin>>n){ int *arr=new int[n]; for(int i=0;i<n;i++){ cin>>arr[i]; } quickSort(arr,0,n-1,n); } } void swap(int &a,int &b){ int t=a; a=b; b=t; } int pfunc(int*arr,int start,int end){ int left=start; int right=end; int hero=arr[start]; while(left<right){ while(left<right && arr[right]>=hero){ right--; } if(left<right){ arr[left]=arr[right]; left++; } while(left<right && arr[left]<=hero){ left++; } if(left<right){ arr[right]=arr[left]; right--; } } arr[left]=hero; return left; } void quickSort(int *arr,int start,int end,int n){ if(start>=end) return; int p=pfunc(arr,start,end); for(int i=0;i<n;i++){ cout<<arr[i]; if(i!=n-1){ cout<<" "; } } cout<<endl; quickSort(arr,start,p-1,n); quickSort(arr,p+1,end,n); }

二路归并排序

注意mergesort 和 merge中对数组的划分能匹配就行了

#include<iostream> using namespace std; void mergeSort(int *arr,int start,int end,int n); void merge(int* arr,int start,int end,int mid); int main(){ int n; while(cin>>n){ int *arr=new int[n]; for(int i=0;i<n;i++){ cin>>arr[i]; } mergeSort(arr,0,n-1,n); } } void mergeSort(int *arr,int start,int end,int n){ if(start==end) return ; int mid=(start+end)/2; mergeSort(arr,start,mid,n); mergeSort(arr,mid+1,end,n); merge(arr,start,end,mid); for(int i=0;i<n;i++){ cout<<arr[i]; if(i!=n-1){ cout<<" "; } } cout<<endl; } void merge(int* arr,int start,int end,int mid){ int* tempArr=new int[end-start+1]; int i=start; int j=mid+1; int k=0; while(i<=mid && j<=end){ if(arr[i]<arr[j]){ tempArr[k]=arr[i]; i++; }else{ tempArr[k]=arr[j]; j++; } k++; } while(i<=mid){ tempArr[k]=arr[i]; i++; k++; } while(j<=end){ tempArr[k]=arr[j]; j++; k++; } for(int n=0;n<end-start+1;n++){ arr[start+n]=tempArr[n]; } }

最大公约数

#include<iostream> using namespace std; int main() { long long a,b; cin>>a>>b; if (a>b) { long long t=a; a=b; b=t; } while (b%a!=0) { long long t=b; b=a; a=t%a; if (a==0) { cout<<0; return 0; } } cout<<a; return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 9:33:56

“ Executor框架: Java多线程的正确打开方式”、“为什么不用自己造轮子? 从Executor框架看线程管理的艺术”、“Java多线程管理,别再 reinvent the wheel! ”

文章目录Executor框架&#xff1a; Java多线程的正确打开方式引言&#xff1a;别再 reinvent the wheel&#xff01;一、Executor框架是什么&#xff1f;1.1 线程管理的艺术1.2 Executor 和 ExecutorService1.3 线程池的分类二、为什么要用 Executor 框架&#xff1f;2.1 线程管…

作者头像 李华
网站建设 2026/6/10 11:41:31

基于 Docker + GitLab + Kubernetes 的 CI/CD 流程实践

基于 Docker GitLab Kubernetes 的 CI/CD 流程实践 一、 引言二、核心概念&#xff1a;CI 与 CD2.1 持续集成&#xff08;Continuous Integration, CI&#xff09;核心目标 2.2 持续部署&#xff08;Continuous Deployment, CD&#xff09;CD 核心价值 三、 Docker GitLab …

作者头像 李华
网站建设 2026/6/10 1:50:31

刘二大人PyTorch深度学习实践第二讲笔记

个新坑&#xff0c;系统学一遍深度学习好做毕设&#xff0c;能到河工大挺激动的&#xff0c;赶紧给刘二大人投自荐简历&#xff0c;但是已读不回&#xff0c;还是自己太菜了........不过已经到河工大了挺好的&#xff0c;梦校第二讲线性模型image-20251125141224993image-20251…

作者头像 李华
网站建设 2026/6/12 17:50:35

再探二分查找

各位好久不见&#xff0c;不知不觉2025都快要结束了&#xff0c;是时候来再总结一次算法&#xff08;入门&#xff09;的经验了。 最近笔者看标准算法库时&#xff0c;注意到C算法库中只有两种二分查找的方法&#xff1a;lower_bound和upper_bound&#xff0c;分别用来查找第一…

作者头像 李华
网站建设 2026/6/12 3:35:00

自动化运维利器Ansible

前言 在如今的IT环境中&#xff0c;服务器数量越来越多&#xff0c;业务流程也越来越复杂。如果还靠手工登录每台服务器操作&#xff0c;不仅效率低&#xff0c;还容易出错。这时候&#xff0c;自动化运维工具就成了运维工程师的“救星”。 Ansible作为其中的佼佼者&#xff0c…

作者头像 李华