int minindex(float array[], int n, int i, int mode)//这是已知的函数
{
int k1,k2, s;
s = array[0];
for (i = 0; i < n; i++)
{
if (array[i] < s)
{
k1 = i;
s = array[i];
}
}
for (i = 0; i < n; i++)
{
if (array[i] > s)
{
k2 = i;
s = array[i];
}
}
if (mode == 0)
{
return k1;
}
else
{
return k2;
}
}
想求各位大佬支招
如何利用上面的函数对一个数组进行排序呢?(我只会纯冒泡法来解决,但要是利用调用函数我就真的不会了)
如何调用已知函数对一数组进行排序?求具体代码过程(已知函数已给)
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- a5156520 2024-01-24 22:19关注
一个实现,如下:
#include <stdio.h> // https://ask.csdn.net/questions/718097 int minindex(float array[], int n, int i, int mode) { //这是已知的函数 int k1,k2, s; s = array[0]; for (i = 0; i < n; i++) { if (array[i] < s) { k1 = i; s = array[i]; } } for (i = 0; i < n; i++) { if (array[i] > s) { k2 = i; s = array[i]; } } if (mode == 0) { return k1; } else { return k2; } } int main(void){ float arr[10]={10,9,8,7,6,1,2,3,4,5}; int n=10; int mode=0; for(int i=0;i<n;i++){ if(i<n-1){ int k=minindex(arr,n-i,i,mode); // printf("before,i=%d,k=%d,arr[%d]=%.0f\n",i,k,i,arr[i]); int temp=arr[n-i-1]; arr[n-i-1]=arr[k]; arr[k]=temp; //printf("after,i=%d,k=%d,arr[%d]=%.0f\n",i,k,i,arr[i]); } } for(int i=0;i<n;i++){ printf("%.0f ",arr[i]); } printf("\n"); return 0; }
解决 无用评论 打赏 举报