基于数组的学习(冒泡排序,选择排序)
今天是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循环中出现的错误。
其实只要细心一点就不会出现这类似的问题。