C语言编程题:用选择法对10个整数排序

使用子函数来做,不能使用指针
2024-12-01 19:20:18
推荐回答(5个)
回答1:

#include<stdio.h>

int main()

{

int i,j,min,t,a[10]={2,4,8,3,6,9,7,222,64,88};

printf("排序前的序列为:\n");

for(i=0;i<10;i++)//输出排序前的序列

{

printf("%5d",a<i>);

}

printf("\n");

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

{

min=i;//把每次循环的第一个数作为最小值

for(j=i+1;j<10;j++)

{

if(a[min]>a[j])

min=j;//交换

}

if(min!=i)//说明第一个数不是最小数,所以将a[i+1]~a[10]中最小值与a<i>对换

{

t=a[min];

a[min]=a<i>;

a<i>=t;

}

}

printf("排序后的序列为:\n");

for(i=0;i<10;i++)//输出排序后的序列

printf("%5d",a<i>);

printf("\n");

return 0;

}

扩展资料:

return表示把程序流程从被调函数转向主调函数并把表达式的值带回主调函数,实现函数值的返回,返回时可附带一个返回值,由return后面的参数指定。

return通常是必要的,因为函数调用的时候计算结果通常是通过返回值带出的。如果函数执行不需要返回计算结果,也经常需要返回一个状态码来表示函数执行的顺利与否(-1和0就是最常用的状态码),主调函数可以通过返回值判断被调函数的执行情况。

回答2:

main()
{int i,j,n,a[10];
printf("输入10个数:");
for(i=0;i<10;i++)
scanf("%d,",&a[i]);//记得输入的时候后面加“,”
for(i=0;i for(j=i;j if(a[i]>a[j]) //改成(a[i] { n=a[i];a[i]=a[j];a[j]=a[i];}
printf("\n由小到大排序结果为:");
for(i=0;i<10;i++)
printf("%d,",a[i]);
}

回答3:

#include
using namespace std;
//#include
int main()
{int i,j,min,temp,a[11];
cout<<"enter data:"< for (i=1;i<=10;i++)
{cout<<"a["< cin>>a[i]; //输入10个数
}
cout< for (i=1;i<=10;i++)
cout< cout< for (i=1;i<=9;i++) //以下8行是对10个数排序
{min=i;
for (j=i+1;j<=10;j++)
if (a[min]>a[j]) min=j;
temp=a[i]; //以下3行将a[i+1]~a[10]中最小者与a[i] 对换
a[i]=a[min];
a[min]=temp;
}
cout< for (i=1;i<=10;i++) // 输出已排好序的10个数
cout< cout< return 0;
}

回答4:

#include
main()
{
int a[10],i,j,t;
printf("please input ten int numbers:");
for(i=0;i<10;i++)
scanf("%d",&a[i]);
for(i=0;i<10;i++)
for(j=i+1;j<10;j++)
if (a[i]>a[j]) {
t=a[i]; a[i]=a[j]; a[j]=t; }
for(i=0;i<10;i++) printf("%d ",a[i]);
}

回答5:

排序有很多种算法。我就随便给你来一个吧。
#include
void Sort(int k[])
{

int x=0,j1,j;
for(j1=0;j1<9;j1++)
{
j=j1+1;
for(j;j<10;j++)
{
if(k[j1]{
x=k[j1];
k[j1]=k[j];
k[j]=x;
}
}
}
for(j=0;j<10;j++)
printf("%d\t",k[j]);
}
int main()
{
int k[10]={84,34,66,45,77,387,57,88,47,32};
Sort(k);//子函数算法
/*int x=0,j1,j;//直接实现
int k[10]={84,34,66,45,77,387,57,88,47,32};
for(j1=0;j1<9;j1++)
{
j=j1+1;
for(j;j<10;j++)
{
if(k[j1]{
x=k[j1];
k[j1]=k[j];
k[j]=x;
}
}
}
for(j=0;j<10;j++)
printf("%d\t",k[j]);
*/
return 0;