南师大GIS考研数据结构2017年第5题

题目

在这里插入图片描述

解答
	#include<stdio.h>
	#include<math.h>
	#define M 10  //需要排序的元素个数
	
	/*冒泡排序*/
	void BubbleSort(int s[],int n){
		int i,j,tag,tmp;
		for(i=n;i>=2;i--){
			tag=0;
			for(j=1;j<=i-1;j++){
				if(s[j]>s[j+1]){
					tmp=s[j];
					s[j]=s[j+1];
					s[j+1]=tmp;
					tag=1;
				}
			}
			if(!tag)
				break;
		}
	}
	
	/*二分查找【递归实现,将mid记录在栈中】*/
	int BinSearch(int t[],int key,int low,int high,int stack[],int *top){
		int mid;
		if(low>high){
			stack[++(*top)]=-1;  //-1表示没找到,记录到栈中
			return 0;  //没找到返回0
		}	
		else{
			mid=(low+high)/2;
			stack[++(*top)]=mid; //将mid记录到栈中
			if(key<t[mid])
				return BinSearch(t,key,low,mid-1,stack,top);
			else if(key>t[mid])
				return BinSearch(t,key,mid+1,high,stack,top);
			else
				return mid;
		}
	}
	
	void Output(int r[],int n){
		int i;
		for(i=1;i<=n;i++){   //从r[1]开始输出,r[0]弃用,不输出
			printf("%d ",r[i]);
		}
		printf("\n");
	}
	
	void main(){
		int key=8,i,res; //假设待查值是7
		int stack[M],top=-1;
		int t[M+1]={0,5,6,7,8,9,10,1,2,3,4}; //r[0]单元弃用
		printf("需要排序的集合为:\n");
		Output(t,M);
		BubbleSort(t,M); //进行冒泡排序【r[0]单元弃用】
		printf("对这10个数进行冒泡排序后(升序):\n");
		Output(t,M);
		res=BinSearch(t,key,1,M,stack,&top);   //二分查找递归【r[0]单元弃用】
		printf("元素%d在排序后集合中的位置为%d\n",key,res);
		printf("栈中依次存储的mid值如下:\n"); //栈最小容量:比以2为底m的对数大的最小整数
		for(i=0;i<=top;i++)
	        printf("第%d次查找的值:%d\n",i,stack[i]);
	}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值