基于数组的学习(冒泡排序,选择排序)

基于数组的学习(冒泡排序,选择排序)

今天是7月11日,学习c语言的第二天,今天主要学习的是有关c语言中的数组的知识。首先讲讲有关数组的概念。
  • 什么是数组

    数组是用来存储一系列数据,但它往往被认为是一系列相同类型的变量。(转载)

  • 声明数组
    在 C 中要声明一个数组,需要指定元素的类型和元素的数量,如下所示:
    type arrayName [ arraySize ];
    这叫做一维数组。arraySize 必须是一个大于零的整数常量,type 可以是任意有效的 C 数据类型。例如,要声明一个类型为 double 的包含 10 个元素的数组 balance,声明语句如下:
    double balance[10];(转载)

  • 初始化数组
    在 C 中,您可以逐个初始化数组,也可以使用一个初始化语句,如下所示:
    double balance[5] = {1000.0, 2.0, 3.4, 7.0, 50.0};
    大括号 { } 之间的值的数目不能大于我们在数组声明时在方括号 [ ] 中指定的元素数目。
    如果您省略掉了数组的大小,数组的大小则为初始化时元素的个数。因此,如果:
    double balance[] = {1000.0, 2.0, 3.4, 7.0, 50.0};
    您将创建一个数组,它与前一个实例中所创建的数组是完全相同的。下面是一个为数组中某个元素赋值的实例:
    balance[4] = 50.0;
    上述的语句把数组中第五个元素的值赋为 50.0。所有的数组都是以 0 作为它们第一个元素的索引,也被称为基索引,数组的最后一个索引是数组的总大小减去 1。
    而在学习数组的过程中排序是能带我们更加深入了解这个知识。(转载)

  • 冒泡排序
    首先看看冒泡排序代码
    #include <stdio.h>
    int main()
    {
    int i;
    int j;
    int t;
    int len;
    int array[6];
    for (i = 0; i < 5; i++)
    {
    scanf("%d",array[i]);
    }
    len=sizeof(array)/sizeof(int);
    for (i = 0; i <len -1 ; i++)
    {
    for (j = 0; j < len-1-i; j++)
    {
    if (array[j]<array[j+1])
    {
    temp=array[j];
    array[j]=array[j+1];
    array[j+1]=temp;
    }
    }
    }
    for (i = 0; i < 5; i++)
    {
    printf("%d\n",array[i]);
    }
    return 0;
    }
    这个算法的主要过程我不好描述,只能根据网上的概念来描述:它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。
    冒泡排序算法的运作如下:(从后往前)
    1.比较相邻的元素。如果第一个比第二个大,就交换他们两个。
    2.对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
    3.针对所有的元素重复以上的步骤,除了最后一个。
    4.持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。(转载)

  • 选择排序
    以下是选择排序的代码:
    #include <stdio.h>
    int main()
    {
    int i;
    int j;
    int temp;
    int len;
    int array[5];
    for (i = 0; i < 5; i++)
    {
    scanf("%d",&array[i]);
    }
    len=sizeof(array)/sizeof(int);
    for (i = 0; i < len-1; i++)
    {
    for (j = i+1; j < len; j++)
    {
    if (array[i]<array[j])
    {
    temp=array[i];
    array[i]=array[j];
    array[j]=temp;
    }
    }
    }
    for (int i = 0; i < len-1; i++)
    {
    printf("%5d\n",array[i] );
    }
    printf("\n");
    return 0;
    }
    选择排序的算法过程是:每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完。 选择排序是不稳定的排序方法(比如序列[5, 5, 3]第一次就将第一个[5]与[3]交换,导致第一个5挪动到第二个5后面)。(转载)

  • 在排序中遇到的错误

在这里插入图片描述
在我代码编译运行后出现了上图中Segmentation fault(core dumped)的错误,我很纳闷,在网上搜了一下,发现出现这个错误的原因多数跟越界和空指针有关,于是我返回去看了下代码,发现了我在for循环中出现的错误。
其实只要细心一点就不会出现这类似的问题。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值