c语言训练的练习题3

文章详细介绍了分治策略在快速排序算法中的实现,通过选取基准元素将大问题分解为小问题解决。同时,展示了如何设计一个分治算法寻找整数序列的最大和最小元素。此外,还提出了一个使用分治法计算指数的算法,针对不同情况(n为奇数或偶数)进行递归处理。
摘要由CSDN通过智能技术生成

 2020010982

1.快速排序算法是根据分治策略来设计的,简述其基本思想。

        对于无序序列a[low..high]进行快速排序,整个排序为“大问题”。选择其中的一个基准base=a[i](通常以序列中第一个元素为基准),将所有小于等于base的元素移动到它的前面,所有大于等于base的元素移动到它的后面,即将基准归位到a[i],这样产生a[low..i-1]和a[i+1..high]两个无序序列,它们的排序为“小问题”。当a[low...high]序列只有一个元素或者为空时对应递归出口。

        所以快速排序算法就是采用分治策略,将一个“大问题”分解为两个“小问题”来求解。由于元素都是在a数组中,其合并过程是自然产生的,不需要特别设计。

2.设计一个算法,采用分治法求一个整数序列中的最大最小元素。

#include <stdio.h>
#define max(x,y) ((x)>(y)?(x):(y))
#define min(x,y) ((x)<(y)?(x):(y))
void MaxMin(int a[],int low,int high,int &maxe,int &mine) //求a中最大最小元素
{ 
	if (low==high) //只有一个元素
	{	 
		maxe=a[low];
		mine=a[low];
	}
	else if (low==high-1) //只有两个元素
	{ 
		maxe=max(a[low],a[high]);
		mine=min(a[low],a[high]);
	}
	else //有两个以上元素
	{ 
		int mid=(low+high)/2;
		int lmaxe,lmine;
		MaxMin(a,low,mid,lmaxe,lmine);
		int rmaxe,rmine;
		MaxMin(a,mid+1,high,rmaxe,rmine);
		maxe=max(lmaxe,rmaxe);
		mine=min(lmine,rmine);
	}
}
int main()
{ 
	int a[]={4,3,1,2,5};
	int n=sizeof(a)/sizeof(a[0]);
	int maxe,mine;
	MaxMin(a,0,n-1,maxe,mine);
	printf("Max=%d, Min=%d\n",maxe,mine);
	return 0;
}

 

 3.设计一个算法,采用分治法求x^n

#include <stdio.h>
int Exponent(int a,int b);
int main(){
	int n,x;
	printf("请输入底数x与幂指数n:\n");
	scanf("%d %d",&x,&n);
	printf("x^n的值为%d",Exponent(x,n));
	return 0;
} 
int Exponent(int x,int n){
	if(n==1)
		return x;
	if(n%2 == 0)
		return Exponent(x,n/2)*Exponent(x,n/2);
	else 
		return Exponent(x,(n-1)/2)*Exponent(x,(n-1)/2)*x;
}

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值