zoukankan      html  css  js  c++  java
  • Algorithm Gossip (42) 循序搜寻法(使用卫兵)

    前言

    This Series aritcles are all based on the book 《经典算法大全》; 对于该书的所有案例进行一个探究和拓展,并且用python和C++进行实现; 目的是熟悉常用算法过程中的技巧和逻辑拓展。

    提出问题

    42.Algorithm Gossip: 循序搜寻法(使用卫兵)

    说明

    不讲解了, 看代码理解。

    分析和解释

    代码

    #include <stdio.h>
    #include <stdlib.h>
    #include <time.h>
    #define MAX 10
    #define SWAP(x,y) {int t; t = x; x = y; y = t;}
    int search(int[]);
    int partition(int[], int, int);
    void quicksort(int[], int, int);
    int main(void) {
    	int number[MAX+1] = {0};
    	int i, find;
    	srand(time(NULL));
    	for(i = 1; i <= MAX; i++)
    		number[i] = rand() % 100;
    	quicksort(number, 1, MAX);
    	printf("数列:");
    	for(i = 1; i <= MAX; i++)
    		printf("%d ", number[i]);
    	printf("
    输入搜寻值:");
    	scanf("%d", &number[0]);
    	if(find = search(number))
    		printf("
    找到数值于索引 %d ", find);
    	else
    	printf("
    找不到数值");
    	printf("
    ");
    	return 0;
    	}
    int search(int number[]) {
    	int i, k;
    	k = number[0];
    	i = MAX;
    	while(number[i] != k)
    		i--;
    	return i;
    	}
    int partition(int number[], int left, int right) {
    	int i, j, s;
    	s = number[right];
    	i = left - 1;
    	for(j = left; j < right; j++) {
    		if(number[j] <= s) {
    			i++;
    			SWAP(number[i], number[j]);
    			}
    		}
    	SWAP(number[i+1], number[right]);
    	return i+1;
    	}
    void quicksort(int number[], int left, int right) {
    	int q;
    	if(left < right) {
    		q = partition(number, left, right);
    		quicksort(number, left, q-1);
    		quicksort(number, q+1, right);
    		}
    	}
    

    拓展和关联

    后记

    参考书籍

    • 《经典算法大全》
    • 维基百科
  • 相关阅读:
    maven-eclipse 中index.html页面乱码
    java-Unsupported major.minor version 52.0错误解决
    eclipse引入httpServlet源码
    eclipse恢复默认布局
    eclipse导入Java源码
    bootstrap fileinput api翻译笔记
    js判断display隐藏显示
    php根据路径获取文件名
    js事件处理-整理
    Jms(消息中间件)两种消息传输方式QUEUE和TOPIC比较
  • 原文地址:https://www.cnblogs.com/actanble/p/6711181.html
Copyright © 2011-2022 走看看