C语言数组排序方法?
C语言将数组元素大小排序方法: 以下使用的是冒泡排序法实线数组从小到大排序。 思想:每次相邻两个数比较,若升序,则将大的数放到后面,一次循环过后,就会将最大的数放在最后。
10、2、3、4、5、6、9、8、7、1是输入的待排序的数列,经过第一次排序,将最大的,10放在最后,第二次排序,将剩下的2、3、4、5、6、9、8、7、1进行冒泡,将当前最大的9放在倒数第二的位置,以此类推。 以下是具体代码:
#include
c#定义一维整数数组,实现数组中的数据由大到小的顺序排列?
c#数组排序可以使用冒泡排序和linq的orderby方法实现
linq实现
数组=数组.orderbydesc();
冒泡排序
int[] nums = { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
//交换时的中间量
int temp;
//比较的趟数
for (int i = 0; i < nums.Length-1; i++)
{
//交换的次数
for (int j = 0; j < nums.Length-1-i; j++)
{
if (nums[j] < nums[j + 1])
{
temp = nums[j];
nums[j] = nums[j + 1];
nums[j + 1] = temp;
}
}
}
//输出冒泡排序后的数组
for (int i = 0; i < nums.Length; i++)
{
Console.Write(nums[i]+" ");
}
Console.ReadKey();
C语言,输入一组数进行排序,由大到小?
#include <stdio.h>
main(void)
{
int i,j,a[10],p=0,t=0,temp;
printf("请输入原数组:\n");
for(j=0;j<10;j++)
scanf("%d",&a[j]);
temp=a[0];
for(j=0;j<9;j++)
{
t=j;
temp=a[j];
for(i=j+1;i<10;i++)
if(temp>a[i]) //这是由小到大排序 如果是大到小则改为 if(temp<a[i])
{temp=a[i];p=i;}
{temp=a[p];a[p]=a[t];a[t]=temp;}
}
printf("排序后的数组为:\n");
for(j=0;j<10;j++)
printf("%d ",a[j]);
}
C语言,如何对二维数组进行按列排序?
在C语言中,二维数组按行存储,对每一行排序很方便,可以把每一行当成一个一维数组,使用排序函数直接进行排序。
然而对每一列进行排序,就不能直接当成一维数组进行排序。但是仍然可以把第j列a[0...M-1][j]在逻辑上当成一维数组进行排序,下面以使用冒泡排序为例对其排序。
对二维数组按列排序后,进一步展示了如何调用快速排序函数按行进行排序。
程序源码:
#include
编译运行后的结果如下:
程序源码和编译后的可执行程序已经打包放在附件里,可以直接下载运行。