开发者社区> 问答> 正文

1、任意输入10个整数,用交换排序法将它们按从小到大的顺序排序并输出。

1、任意输入10个整数,用交换排序法将它们按从小到大的顺序排序并输出。

展开
收起
知与谁同 2018-07-15 16:56:55 2684 0
3 条回答
写回答
取消 提交回答
  • 用VB。
    有排序法 和 冒泡法...

    你在百度搜索一下就有,很方便。

    我们的课本上面有例题..《VB程序设计》 王栋 著 清华大学出版社
    2019-07-17 22:50:25
    赞同 展开评论 打赏
  • 两个for循环嵌套就出来了
    int[] nN = {1,2,3,4,5,6,7,8,9,0};
    int nT = 0;
    for (int i=0;i<10;i++)
    {
    for (int j=0;j<10;j++)
    {
    if (nN[i]<nN[j])
    {
    nT = nN[i];
    nN[i] = nN[j];
    nN[j] = nT;
    }
    }
    }
    2019-07-17 22:50:25
    赞同 展开评论 打赏
  • 合并排序(MERGE SORT)是又一类不同的排序方法,合并的含义就是将两个或两个以上的有序数据序列合并成一个新的有序数据序列,因此它又叫归并算法。它的基本思想就是假设数组A有N个元素,那么可以看成数组A是又N个有序的子序列组成,每个子序列的长度为1,然后再两两合并,得到了一个 N/2 个长度为2或1的有序子序列,再两两合并,如此重复,值得得到一个长度为N的有序数据序列为止,这种排序方法称为2—路合并排序。

    例如数组A有7个数据,分别是: 49 38 65 97 76 13 27,那么采用归并排序算法的操作过程如图7所示:

    初始值 [49] [38] [65] [97] [76] [13] [27]

    看成由长度为1的7个子序列组成

    第一次合并之后 [38 49] [65 97] [13 76] [27]

    看成由长度为1或2的4个子序列组成

    第二次合并之后 [38 49 65 97] [13 27 76]

    看成由长度为4或3的2个子序列组成

    第三次合并之后 [13 27 38 49 65 76 97]

    合并算法的核心操作就是将一维数组中前后相邻的两个两个有序序列合并成一个有序序列。合并算法也可以采用递归算法来实现,形式上较为简单,但实用性很差。合并算法的合并次数是一个非常重要的量,根据计算当数组中有3到4个元素时,合并次数是2次,当有5到8个元素时,合并次数是3次,当有9到16个元素时,合并次数是4次,按照这一规律,当有N个子序列时可以推断出合并的次数是X(2 >=N,符合此条件的最小那个X)。
    其时间复杂度为:O(nlogn).所需辅助存储空间为:O(n)

    归并算法如下:
    long merge(long *A,long p,long q,long r)
    {
    long n1,n2,i,j,k;
    long *L,*R;
    n1=q-p+1;
    n2=r-q;
    L=(long *)malloc((n1+2)*sizeof(long));
    R=(long *)malloc((n2+2)*sizeof(long));
    for(i=1;i<=n1;i++)
    L=A[p+i-1];
    for(j=1;j<=n2;j++)
    R[j]=A[q+j];
    L[n1+1]=R[n2+1]=RAND_MAX;
    i=j=1;
    for(k=p;k<=r;k++)
    {
    if(L<=R[j])
    {
    A[k]=L;
    i++;
    }
    else
    {
    A[k]=R[j];
    j++;
    }
    }
    free(L);
    free(R);
    return 0;
    }

    long mergesort(long *A,long p,long r)
    {
    long q;
    if(p<r)
    {
    q=(p+r)/2;
    mergesort(A,p,q);
    mergesort(A,q+1,r);
    merge(A,p,q,r);
    }
    return 0;
    }
    2019-07-17 22:50:25
    赞同 展开评论 打赏
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载