matlab如何将一个一维数组从大到小排序

刚刚试了sort() 是从小到大 如何从大到小呢

matlab一维数组将数据从大到小排列使用矩阵排列,俗称“起泡法”,方法思想如下:

第一、用两个并列的for循环语句,在第二个for 语句中又嵌套了一个循环语句。第一个for语句用于输入10个元素的初值。第二个for语句用于排序。本程序的排序采用逐个比较的方法进行。

第二、在i次循环时,把第一个元素的下标i赋于p,而把该下标变量值a[i]赋于q。然后进入小循环,从a[i+1]起到最后一个元素止逐个与a[i]作比较,有比a[i]大者则将其下标送p,元素值送q。 一次循环结束后,p即为最大元素的下标,q则为该元素值。

第三若此时i≠p,说明p,q值均已不是进入小循环之前所赋之值,则交换a[i]和a[p]之值。 此时a[i]为已排序完毕的元素。输出该值之后转入下一次循环。对i+1以后各个元素排序。

在C语言中对数组排列也是可以的,代码如下:
include<stdio.h>
#include<stdlib.h>
main()
{
      int a[10],i,j,t;
      for(i=0;i<10;i++)
                       scanf("%d",&a[10]);
      for(i=0;i<9;i++)
      {for(j=0;j<9-i;j++)
       {
                         if(a[j]<a[j+1])
                         {t=a[j];a[j]=a[j+1];a[j+1]=t;}
       }
      }
      for(i=0;i<10;i++)
      printf("%d ",a[i]);
      getch();
      }

温馨提示:答案为网友推荐,仅供参考
第1个回答  2015-04-16
sort(A,'descend')本回答被提问者采纳
相似回答