Acwing算法基础课(更新中......)

算法:

一:快排: 
1.确定分界点 
2.调整区间
3.递归处理左右两边 

785. 快速排序 - AcWing题库

#include<iostream>
using namespace std;
const int N=100001;//注意分清数字范围(int)和数据范围 
int n,q[N]; 
void quick_sort(int q[],int l,int r)
{
	if(l>=r)return;//先排好序 
	int x=q[l],i=l-1,j=r+1;//1,定义两个指针,先向两边扩一位 
	  //x=q[l+r>>1]               
	while(i<j)//2,迭代 
	{
		do i++;while(q[i]<x);
		do j--;while(q[j]>x);//边界不能写等于!!! 
		if(i<j)swap(q[i],q[j]);//两指针相遇时 
	}
	quick_sort(q,l,j);//3 
	quick_sort(q,j+1,r);
	
}
int main()
{
	cin>>n;
	for(int i=1;i<=n;i++)
	cin>>q[i];
	quick_sort(q,1,n);//左闭右闭 
	for(int i=1;i<=n;i++)
	cout<<q[i]<<' ';
}

786. 第k个数 - AcWing题库        

法一:快排

#include<iostream>
using namespace std;
const int N=100001;
int n,k,q[N];
void quick_sort(int q[],int l,int r)
{
	if(l>=r)return;
	int x=q[l],i=l-1,j=r+1;
	while(i<j)
	{
		do i++;while(q[i]<x);
		do j--;while(q[j]>x);
		if(i<j)swap(q[i],q[j]);
	}
	quick_sort(q,l,j);
	quick_sort(q,j+1,r);
}
int main()
{
	cin>>n>>k;
	int i; 
	for(i=1;i<=n;i++)
	cin>>q[i];
	quick_sort(q,1,n);//左闭右闭 
	
	cout<<q[k];//直接输出第k个数 
 } 

法二:sort

#include<iostream>
#include<algorithm>
using namespace std;
const int N=1e5+10;
int n,k,q[N];
int main()
{
	cin>>n>>k;
	for(int i=1;i<=n;i++)
	cin>>q[i];
	sort(q+1,q+n+1);//sort一般是左闭右开(默认升序) 
	cout<<q[k];
 } 
 
 /*#include<iostream>
#include<algorithm>
using namespace std;
const int N=1e5+10;
int n,k,q[N];
int main()
{
    cin>>n>>k;
    for(int i=1;i<=n;i++)
    cin>>q[i];
    sort(q,q+n+1);//sort(q+1,q+n+1);都可因为从1开始,0不用浪费了 
    cout<<q[k];
}*/

法三:nth_element

#include<iostream>
#include<algorithm>
using namespace std;
const int N=1e5+10;
int n,k,q[N];
int main()
{
	cin>>n>>k;
	
	for(int i=1;i<=n;i++)
	cin>>q[i];
	
	nth_element(q,q+k,q+n+1);//左闭右开 
	                     //(数组名,数组名+第k个数,数组名+一共多少数加一)
	                    /*nth_element的作用就是根据nth这个参数,
						把容器内的元素分为2组,nth之前的都比它小,
						nth之后的都比它大*/ 
	cout<<q[k];
 } 

 二:归并:

1.确定分界点

2.递归处理左右两边

3.归并:合二为一

787. 归并排序 - AcWing题库

/*归并: 
(1)确定分界点
(2)递归处理左右两边
(3)归并:合二为一 
*/
#include<iostream>//不理解了就记住每个比较都写等号,评论区大佬可留言 
using namespace std;
const int N=1E5+10;
//int k;k不能定义成全局变量,不然每次使用时都会从0开始 
int n,q[N],tmp[N];
void merge_sort(int q[],int l,int r)//闭区间[l,r] 
{
	if(l>=r)return;
	int m=l+r>>1;//(1)m=l+r>>1与m=(l+r)/2的含义一样,都是向下取整 
	
	merge_sort(q,l,m);//(2)
	merge_sort(q,m+1,r);
	 
	int k=0,i=l,j=m+1;//定义两个指针:i指向左边的起点,j指向右边的起点 
	while(i<=m&&j<=r)//(3)循环为空时停止(只要有一个里面的数用完了就停止) 
		if(q[i]<=q[j])tmp[k++]=q[i++];//比较q[i],q[j]值的大小,将小的放到tmp中 
		else tmp[k++]=q[j++];
		
		while(i<=m)tmp[k++]=q[i++];//将多余的全部放入tmp 
		while(j<=r)tmp[k++]=q[j++];
		
		for(int i=l,j=0;i<=r;i++,j++) 
		q[i]=tmp[j];//将数据存入q[i] 
}
int main()
{
	cin>>n;
	for(int i=1;i<=n;i++)
	cin>>q[i];
	merge_sort(q,1,n);
	for(int i=1;i<=n;i++)
	cout<<q[i]<<' ';
} 

三:二分:

1.确定一个区间,使目标值在此区间中

2.找一个性质,这个性质具有二段性,答案是二段性的分界点

789. 数的范围 - AcWing题库

#include<iostream>
using namespace std;
const int N=1e5+10;
int n,m,q[N]; 
int main()
{

	cin>>n>>m;//一共n个数,m个询问 
	for(int i=0;i<n;i++)
	cin>>q[i];
	
	while(m--)
	{
		int x;
		cin>>x;
		int l=0,r=n-1;//l,r写上边,mid写下边!!! 
		while(l<r)
		{
			int mid=l+r>>1;
			if(q[mid]>=x)r=mid;
			else l=mid+1;
		}
		if(q[l]!=x)cout<<"-1 -1"<<endl;
		else
		{
			cout<<l<<' ';
			int l=0,r=n-1;
			while(l<r)
			{
				int mid=l+r+1>>1;
				if(q[mid]<=x)l=mid;
				else r=mid-1;
			}
			cout<<l<<endl;
		}
	}
}

790. 数的三次方根 - AcWing题库

#include<iostream>
using namespace std;
int main()
{
	double x;
	cin>>x;
	
	double l=-1000,r=1000;//
	while(r-l>1e-8) 
	{
		double mid=(l+r)/2;
		if(mid*mid*mid>=x)//mid的值取大了,所以要把l往左移,缩小区间 
		r=mid;
		else l=mid;
	}
	printf("%.6lf",l);
 } 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: acwing算法基础课是一门针对算法学习的在线课程,在这门课程,学生可以系统地学习和掌握算法基础知识,提高编程水平。为了方便学生学习,acwing提供了网盘服务。 acwing算法基础课网盘是一个用于存储课程资源的平台。通过这个网盘,学生可以下载课程讲义、代码模板以及补充材料等。这些资源都经过精心整理,供学生们参考和学习。 网盘资源是按照课程章节进行分类的,学生可以根据自己的学习需要,选择性地下载所需的资料。同时,网盘还提供了搜索功能,方便学生快速定位和获取所需资料。 acwing算法基础课网盘的使用对于学生们的学习非常有帮助。通过下载和学习这些资源,学生们可以更好地理解课程内容,加深对算法的理解。此外,学生们还可以通过研究代码模板,学习优秀的编程思想和技巧,提高自己的编程能力。 总之,acwing算法基础课网盘是一项非常便利和实用的服务,为学生们提供了更加全面和深入的学习资源,帮助他们更好地掌握和运用算法知识。 ### 回答2: acwing算法基础课是一门优质的算法学习资源,其的课程内容丰富多样,涵盖了算法基础知识、数据结构、动态规划、图论等等。很多学习者都认为这门课程对他们的算法学习有很大的帮助。 网盘是指以网络为媒介,提供文件存储和下载服务的云存储平台。acwing算法基础课也提供了网盘服务,方便学习者下载课程资料并进行学习。 通过acwing算法基础课网盘,学习者可以方便地获取到课程的各种学习资料,包括讲义、习题集、代码示例等。这些资料可以帮助学习者更好地理解和掌握课程的内容。此外,网盘还提供了上传和分享功能,学习者可以将自己的学习心得、代码等资料分享给其他学习者,促进学习者之间的互相学习和交流。 acwing算法基础课网盘的优点不仅仅是方便快捷的下载和分享功能,还包括安全可靠的存储环境。学习者可以放心地将自己的学习资料上传到网盘进行备份,减少数据丢失的风险。同时,网盘还提供了多种存储空间容量的选择,满足学习者不同的需求。 总的来说,acwing算法基础课网盘为学习者提供了方便、安全和多样化的学习资源下载和分享服务,为学习者的算法学习和进步提供了有力的支持。如果你对算法感兴趣,我推荐你去尝试一下这门精彩的课程!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值