数组排序,并返回排序后的数组对应原数组的下标(c语言)
2015-10-20 15:18
525 查看
#include<stdio.h>
#include<stdlib.h>
void sort(int* a, int length, int* b)
{
int i,j, t1, t;
for(j=0; j<length; j++)
for(i=0; i<length-1-j; i++)
if(a[i]<a[i+1])
{
t=a[i];
a[i]=a[i+1];
a[i+1]=t;
t1=b[i];
b[i]=b[i+1];
b[i+1]=t1;
}
}
int main()
{
int a[] = {0,0,3,0,4,0,0};
int b[7] = {0,1,2,3,4,5,6};//用来保存原数组对应的下标以及排序后的下标
sort(a, 7, b);
printf("排序后的数组为:\n");
for(int i=0; i<7; i++)
printf("%d ",a[i]);
printf("\n");
printf("排序后的数组对应的下标:\n");
for(int i=0; i<7; i++)
printf("%d ",b[i]);
printf("\n");
return 0;
}
#include<stdlib.h>
void sort(int* a, int length, int* b)
{
int i,j, t1, t;
for(j=0; j<length; j++)
for(i=0; i<length-1-j; i++)
if(a[i]<a[i+1])
{
t=a[i];
a[i]=a[i+1];
a[i+1]=t;
t1=b[i];
b[i]=b[i+1];
b[i+1]=t1;
}
}
int main()
{
int a[] = {0,0,3,0,4,0,0};
int b[7] = {0,1,2,3,4,5,6};//用来保存原数组对应的下标以及排序后的下标
sort(a, 7, b);
printf("排序后的数组为:\n");
for(int i=0; i<7; i++)
printf("%d ",a[i]);
printf("\n");
printf("排序后的数组对应的下标:\n");
for(int i=0; i<7; i++)
printf("%d ",b[i]);
printf("\n");
return 0;
}
相关文章推荐
- 文件遍历排序函数
- ruby 数组使用教程
- Ruby中的数组和散列表的使用详解
- C#实现AddRange为数组添加多个元素的方法
- C#选择排序法实例分析
- C#动态调整数组大小的方法
- C#插入法排序算法实例分析
- Lua和C语言的交互详解
- 详解Lua中的数组概念知识
- C#实现Datatable排序的方法
- Perl中的列表和数组学习笔记
- 探索PowerShell (八) 数组、哈希表(附:复制粘贴技巧)
- C#中数组初始化与数组元素复制的方法
- C#交错数组用法实例
- SQLSERVER的排序问题结果不是想要的
- Linux Shell 数组建立及使用技巧
- PowerShell数组的一些操作技巧
- Windows Powershell排序和分组管道结果
- C#通过yield实现数组全排列的方法
- C#不重复输出一个数组中所有元素的方法