【程序设计】
--------------------------------------------------
功能:编写函数用冒泡排序法对数组中的数据进行从小到
大的排序。
*********Begin**********和********** End **********不可删除
------------------------------------------------*/
#include "stdlib.h"
#include "stdio.h"
void sort(int a[],int n)
{
/*********Begin**********/
/********** End **********/
}
main()
{
int a[16],i;
void TestFunc();
for(i=0;i<16;i++)
a[i]=rand()%30;
for(i=0;i<16;i++)
printf("%3d",a[i]);
printf("\n-------------------\n");
sort(a,16);
for(i=0;i<16;i++)
printf("%3d",a[i]);
TestFunc();
}
void TestFunc()
{
FILE *IN,*OUT;
int n;
int i[10];
IN=fopen("in.dat","r");
if(IN==NULL)
{
printf("Read File Error");
}
OUT=fopen("out.dat","w");
if(OUT==NULL)
{
printf("Write File Error");
}
for(n=0;n<10;n++)
{
fscanf(IN,"%d",&i[n]);
}
sort(i,10);
for(n=0;n<10;n++)
fprintf(OUT,"%d\n",i[n]);
fclose(IN);
fclose(OUT);
}
之间写这个
追问请问您能解答一下这几个步骤吗?
追答这是冒泡排序的核心思想(泡泡越往上浮,体积越大),基本思路:将相邻的两个数比较,通过交换位置将较大的数放在后面(从小到大排序)或将较小的数放在后面(从大到小排序),一直比较到最后一个数,这样的话,最大(或最小的数)将会放在最后面,称之为归位。接下来,将第二大(或第二小)的数通过交换放到第二个位置,经过多次比较,数列会趋于有序状态。
以数组3,6,4,2,1为例
第一次循环:6与4交换位置,变成3,4,6,2,1;6与2交换,变成3,4,2,6,1;6与1交换变成3,4,2,1,6。
现在解释代码的详细步骤:
外层for循环,是执行的次数。比如数组的大小为n,那么进行n-1次归位,剩下的一个数已经被迫归位了。
内层for循环,是遍历所有要比较的数,条件j<n-1-1是因为已经归位的数不用再比较。
if条件里的就是,将较大的数交换到后面(如果后面的数本来就大就不用交换),通过不停的交换,使数到达应该它在的位置。
不知道我解释清楚没有,你可以脑补一下算法的过程。
C语言:编写函数用冒泡排序法对数组中的数据进行从小到大的排序.
int i,j,temp;for(i=0;i<n-1;i++){for(j=0;j<n-1-i;j++){if(a[j]>a[j+1]){temp=a[j];a[j]=a[j+1];a[j+1]=temp;}}}之间写这个
一道C语言题目,编写函数用冒泡排序法对数组中的数据进行从小到大的排序...
1、新建一个163.php。2、输入php网页的结构(<?php?>)。3、声明PHP与浏览器交互的文件类型和编码。4、使用 array() 函数定义一个$numbers数组。5、使用 sort() 函数对数组 $numbers 中的元素进行排序。6、使用 print_r() 函数,输出排序后的数组。7、运行网页,在浏览器中输出排序后的数组。
C语言:冒泡排序法将数组中10个元素从小到大排序,并找出最小值?_百度...
这段代码包含了冒泡排序算法,用于将数组中的元素从小到大排序,并寻找数组中的最小值。代码首先读取10个整数,然后初始化最小值`min`为数组的第一个元素。接下来,通过一个循环遍历数组,用一个if语句来更新`min`,如果找到一个比当前`min`小的值,就更新它。之后,冒泡排序的逻辑开始执行。这里使用...
C语言:采用冒泡排序方法,对10个数按由小到大的的顺序排序
代码如下(对10个整数进行升序排序):include<stdio.h> int main(){ int i,j,t,a[10]={5,4,8,3,6,9,7,222,64,88};\/\/排序 for(i=1;i<10;i++)\/\/外循环控制排序趟数,n个数排n-1趟 { for(j=0;j<10-1;j++)\/\/内循环每趟比较的次数,第j趟比较n-i次 { if(a[j]>a...
C语言:冒泡排序法将数组中10个元素从小到大排序,并找出最小值?_百度...
int a[11],min=0,t;for(int i=0;i<10;i++)scanf("%d",&a[i]);min=a[0];for(int i=0;i<10;i++)if(a[i]<min)\/\/求最小值 min=a[i];for(int i=0;i<10;i++)\/\/冒泡排序 for(int j=0;j<9-i;j++)if(a[j]>a[j+1]){ t=a[j];a[j]=a[j+1];a[j+1...
用c语言程序设计:输入5个整数,利用冒泡排序法,从小到大排序后输出。
val++)scanf("%d",&a[val]);for(int i=0;i<=4;i++){for(int j=i+1;j<=4;j++){if(a[i]>a[j]){int tmp;tmp = a[i];a[i] = a[j];a[j] = tmp;}}}printf("排序后:");for(int k = 0;k<=4;k++) printf("%d ",a[k]);}截图坏了,自己运行吧 ...
编写一个sort函数,使用冒泡法对数组a中n个整数由小到大进行排列,用C程 ...
include "stdio.h"void sort(int* arr, int n){int i,j,t;for(i=0;i<n;i++){ for(j=0;j<n-i-1;j++){ if(arr[j]>arr[j+1]){ t=arr[j];arr[j]=arr[j+1];arr[j+1]=t;} } } } void main(){ int i,a[100],n;scanf("%d",&n);for(i=0;i<n;i++){ ...
C语言:写一函数,用“冒泡法”对输入的10个字符按由小到大顺序排列
冒泡排序需要用到两层循环,第一层循环遍历数组中的元素,第二层则进行两两比较,如果顺序不对就要对其进行换位,直到排序完成:4、最后执行程序观察结果,按下crtl+F5弹出程序,随意输入10个数,按下回车键执行结果,此时就可以看到排序后的结果了。以上就是c语言冒泡排序程序的演示:...
C语言冒泡法排序:任意输入十个数排序(从小到大;从大到小)
从大到小:include<stdio.h> define N 10 void main(){ int i,j;float a[N],t;printf("排序前:\\n");for(i=0;i<N;i++){ scanf("%d",&a[i]);} for(i=0;i<N;i++){ printf("%6.1f",a[i]);} printf("\\n");for(i=0;i<N-1;i++){ for(j=0;j<N-i-1;j++...
...函数调用排序子函数,对n个整数进行从小到大的排序,谢了
include<stdio.h> void sort(int a[],int n){ int i;int j;for(i=1;i<n;i++) \/\/n个程序 排n-1次 { for(j=0;j<n-i;j++){ if(a[j]>a[j+1]) \/\/从小到达,前面的比后面的大,则互换。{ int temp = a[j];a[j] = a[j+1];a[j+1] = temp;} } } } i...