函数问题请教各位!!

用函数写一个简单排序法,将一维数组排序,编译已通过,但结果不正确,是因为函数只能返回一个值吗?应该怎么修改程序,才能从函数中返回排序后的一维数组啊?谢谢指点,#inclu... 用函数写一个简单排序法, 将一维数组排序,编译已通过,但结果不正确,是因为函数只能返回一个值吗?应该怎么修改程序,才能从函数中返回排序后的一维数组啊?谢谢指点,

#include<stdio.h>

void a1(int b[],int n)
{
int j,k,l,m;
for(j=1;j<n-1;j++)
{
l=j;
for(k=j+1;k<n;k++)
{
if(b[k]<b[l]) l=k;
if(l!=j)
{
m=b[j];
b[j]=b[l];
b[l]=m;
}
}
}
}

main()
{
int a[10],i;
printf("please input a:\n");
for(i=0;i<10;i++)
scanf("%d",&a[i]);
printf("please input b:\n");
a1(a,10);

for(i=0;i<10;i++)

printf("% d",a[i]);
getch();
}
展开
 我来答
TeaNW
2007-06-19 · TA获得超过363个赞
知道小有建树答主
回答量:87
采纳率:0%
帮助的人:0
展开全部
你的a1函数有问题: 改成下面的
void a1(int b[],int n)
{
int j,k,l,m;
for(j=0;j<n-1;j++) /*j初始为0*/
{
l=j;
for(k=j+1;k<n;k++)
{
if(b[k]<b[l]) l=k;
}
if(l!=j) /*交换操作放到外层循环中*/
{
m=b[j];
b[j]=b[l];
b[l]=m;
}
}
}
TableDI
2024-07-18 广告
VLOOKUP是Excel中的常用函数,用于在表格的首列中查找值,并返回该行中指定列的值。其基本语法为:`VLOOKUP(lookup_value, table_array, col_index_num, [range_lookup])`。... 点击进入详情页
本回答由TableDI提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式