C语言【顺序表】冒泡排序,一次选出最大最小的数据,二分查找,初始化顺序表

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<assert.h>
#include<stdlib.h>
#include<string.h>

#define MAX_SIZE 5
typedef int DataType;

typedef struct SeqList
{
    size_t size;
    DataType array[MAX_SIZE];
}SeqList;

//冒泡排序

//void swap(DataType *left, DataType *right)
//{
//    DataType tmp = *left;
//    *left = *right;
//    *right = tmp;
//}
//
//void BubbleSort(SeqList* pSeq)
//{
//    int i = 0;
//    int j = 0;
//    int flag = 0;
//    assert(pSeq);
//    for (i = 0; i < pSeq->size - 1; i++)
//    {
//        for (j = 1; j < pSeq->size - i; j++)
//        {
//            if (pSeq->array[j - 1]> pSeq->array[j])
//            {
//                swap(&pSeq->array[j - 1], &pSeq->array[j]);
//                flag = 1;
//            }
//        }
//        if (flag == 0)
//        {
//            return;
//        }
//    }
//}
//
//void Test1()
//{
//    SeqList List;
//    BubbleSort(&List);
//}
//
//int main()
//{
//    Test1();
//    system("pause");
//    return 0;
//}

// 一次选出最大最小的数据分别放在序列的两端
//void SeclectSort(SeqList* pSeq)
//{
//    int i, j;
//    int min;
//    assert(pSeq);
//    for (j = 0; j < pSeq->size - 1; ++j)
//    {
//        min = j;
//        for (i = j + 1; i < pSeq->size; ++i)
//        {
//            if (pSeq->array[min] > pSeq->array[i])
//            {
//                min = i;
//            }
//        }
//        Swap(&pSeq->array[min], &pSeq->array[j]);
//    }
//}
//
//void SeclectSort_OP(SeqList* pSeq)
//{
//    int left = 0, right = pSeq->size - 1;
//    int min, max, i;
//    assert(pSeq);
//
//    while (left < right)
//    {
//        for (i = left; i <= right; i++)
//        {
//            if (pSeq->array[i] < pSeq->array[left])
//            {
//                Swap(&pSeq->array[i], &pSeq->array[left]);
//            }
//
//            if (pSeq->array[i] > pSeq->array[right])
//            {
//                Swap(&pSeq->array[i], &pSeq->array[right]);
//            }
//        }
//
//        ++left;
//        --right;
//    }
//}
//void Test2()
//{
//    SeqList List;
//    SeclectSort(&List);
//    SeclectSort_OP(&List);
//}
//
//int main()
//{
//    Test2();
//    system("pause");
//    return 0;
//}

//
//int BinarySearch(SeqList* pSeq, DataType x)
//{
//    int left = 0;
//    int right = pSeq->size;
//    assert(pSeq);
//    while (left <= right)
//    {
//        int mid = left - (left - right) / 2;
//        if (x > pSeq->array[mid])
//        {
//            left = mid + 1;
//        }
//        else if (x < pSeq->array[mid])
//        {
//            right = mid - 1;
//        }
//        else
//        {
//            return mid;
//        }
//    }
//    return -1;
//}
//
//void Test3()
//{
//    SeqList List;
//    BinarySearch(&List, 5);
//}

//int main()
//{
//    Test3();
//    system("pause");
//    return 0;
//}

//void InitSeqList(SeqList* pSeq)
//{
//    assert(pSeq);
//    memset(pSeq->size, 0, sizeof(DataType)*MAX_SIZE);
//    pSeq->size = 0;
//}
时间: 2024-10-12 18:13:26

C语言【顺序表】冒泡排序,一次选出最大最小的数据,二分查找,初始化顺序表的相关文章

查找算法:二分查找、顺序查找

08年9月入学,12年7月毕业,结束了我在软件学院愉快丰富的大学生活.此系列是对四年专业课程学习的回顾,索引参见:http://blog.csdn.net/xiaowei_cqu/article/details/7747205 查找算法 查找算法是在存在的序列(list) 中查找特定的目标(target),要求序列中每个记录必须与一个关键词(key)关联才能进行查找. 查找算法通常需要两个输入: 1.被查找的序列 2.要查找的关键词 查找算法的输出参数和返回值: 1.返回类型为 Error_co

算法-基础和查找-1.汉诺塔/2.顺序查找/3.二分查找/4.顺序查找和二分查找的比较

1.汉诺塔: 如下图所示,需要将A柱子中的所有圆盘按照从小到大的顺序移动到C柱子上,并且在移动过程中大圆盘不能在小圆盘上面 分析问题:最终希望呈现的结果是将A柱子上的盘子全部按照从小到大的顺序移动到C柱子上 1.n个盘子,将n-1视为一个整体 2.将n-1个盘子视为一个盘子从a经过c移动到b 3.将n从a移动到c 4.将n-1个盘子从b经过a移动到c 5.结束条件:n>0 代码如下: 1 def hanoi(n, a, b, c): 2 if n > 0: 3 hanoi(n-1, a, c,

ORA-03206,当表空间不够时,如何以添加数据文件的方式扩展表空间

准备导入一个数据库,大约为33G,开始创建的空库表空间为自增到20G,结果自然不够,然后就开始自动扩展表空间大小 使用的如下语句 --自动扩展表空间大小 ALTER DATABASE DATAFILE 'E:\app\oracle\oradata\ORCL\WORKFLOW01.ora' AUTOEXTEND ON NEXT 200M MAXSIZE 60000M; 然后就提示 ORA-03206,块大小超出范围云云 查了一下说是单个文件最大为32G,这里自增的有将近60G,所以就报错了 看了很

冒泡排序法与二分查找法

冒泡排序(Bubble Sort) 是一种计算机科学领域的较简单的排序算法. 它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成. 这个算法的名字由来是因为越大的元素会经由交换慢慢“浮”到数列的顶端,故名. 算法原理 冒泡排序算法的运作如下:(从后往前) 比较相邻的元素.如果第一个比第二个大,就交换他们两个. 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对.在这一点,最后的元素应该

C++——类继承以及类初始化顺序

对于类以及类继承, 几个主要的问题:1) 继承方式: public/protected/private继承. 这是c++搞的, 实际上继承方式是一种允许子类控制的思想. 子类通过public继承, 可以把基类真实还原, 而private继承则完全把基类屏蔽掉. 这种屏蔽是相对于对象层而言的, 就是说子类的对象完全看不到基类的方法, 如果继承方式是private的话, 即使方法在基类中为public的方法. 但继承方式并不影响垂直方向的访问特性, 那就是子类的函数对基类的成员访问是不受继承方式的影

查找算法(I) 顺序查找 二分查找 索引查找

查找 本文为查找算法的第一部分内容,包括了基本概念,顺序查找.二分查找和索引查找.关于散列表和B树查找的内容,待有空更新吧. 基本概念 查找(search)又称检索,在计算机上对数据表进行查找,就是根据所给条件查找出满足条件的第一条记录(元素)或全部记录. 若没有找到满足条件的记录,则返回特定值,表明查找失败:若查找到满足条件的 第一条记录,则表明查找成功,通常要求返回该记录的存储位置或记录值本身,以便进行进一步处理:若需要查找到满足条件的所有记录,则可看做在多个区间内连 续查找到满足条件的第一

分块查找\索引顺序查找

简介: 分块查找又称索引顺序查找,它是顺序查找的一种改进方法,性能优于顺序查找. 方法描述: 将n个数据元素"按块有序"划分为m块(一般块的长度均匀,最后一块可以不满)(m<=n),每一块中的节点不必有序,但块与块之间必须"按块有序":即第一块中的关键字必须小于(或者大于)第二块中的关键字,第二块中的关键字必须小于(或者大于)第三块中的关键字,构造索引表,索引表按关键字有序排列. 如下图所示: 图示为一个索引顺序表,其中包括三个块,第一个块的其实地址为0,快内

2. C#数据结构与算法 -- 查找算法(顺序查找,哈希查找,二分查找(折半),索引,二叉)

1. 顺序查找算法 ===================================================== 算法思想简单描述: 最突出的查找类型就是从记录集的开始处顺次遍历每条记录,直到找到所要的记录或者是 到达数据集的末尾.这就是所谓的顺序查找.顺序查找(也被称为线性查找)是非常容易实现 的.从数组的起始处开始,把每个访问到的数组元素依次和所要查找的数值进行比较.如果找 到匹配的数据项,就结束查找操作.如果遍历到数组的末尾仍没有产生匹配,那么就说明此数 值不在数组内. ==

选择排序、冒泡排序、快速排序和二分查找的C语言实现

1 #include <stdio.h> 2 3 #define ASC 0 //升序,从左到右,从小到大 4 #define DESC 1 //降序,从左到右,从大到小 5 #define TRUE 1 //布尔值,真 6 #define FALSE 0 //布尔值,假 7 8 typedef int datatype; //定义数组元素的类型,这里暂定为int 9 10 void selectSort(datatype array_to_sort[], int length, int mo