C语言从键盘输入10个数,使用冒泡法对这10个数进行排序。要求使用指针实现。 8、编程实现:从键盘上输入10个整数,对10个整数进行冒泡排...

作者&投稿:耿钓 (若有异议请与网页底部的电邮联系)

#include<stdio.h>

voidBubbleSort(inta[],intn)

int i,j,temp,flag=1;

for(i=0;i<n-1&&flag;i++)//比较的趟数

flag=0;//未进行比较,将flag置0

for(j=0;j<n-1-i;j++)//每趟比较的次数

if(a[j]>a[j+1])//由小到大排序

temp=a[j];

a[j]=a[j+1];

a[j+1]=temp;

flag=1;//若进行了比较,则将flag置1

void main()

int a[10],i;

printf("pleaseinput10numbers:\n");

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

scanf("%d",&a[i]);

printf("Thearrayis:\n");

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

printf("%-4d",a[i]);

BubbleSort(a,10);

printf("\nAftersortthearrayis:\n");

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

printf("%-4d",a[i]);

printf("\n");

运行效果:

扩展资料:

main()函数用法:

1、大多数UNIX系统对main函数提供了三个参数,原型如下:

intmain(intargc,char*argv[],char*env[]);其中第三个参数是环境表地址。ANSIC规定main函数只有两个参数,而且第三个参数与全局变量environ相比也没有带来更多益处,所以POSIX.1也规定应使用environ而不使用第三个参数。

2、通常用getenv和putenv函数来存取特定的环境变量,而不是用environ变量。

main函数的原型多是下面这种形式:

intmain(intargc,char*argv[]),参数argc代表了输入参数的个数,char*argv[]表示传入的参数的字符串,是一个字符串数组。

例如在linux平台下编写一个小程序:

int main(intargc,char*argv[])

int i;

printf("argc:%d\n",argc);

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

printf("argv[%d]:%s\n",i,argv[i]);

exit(0);

3、用gcc编译后形成一个a.out的可执行的文件,运行a.out,其结果是:

argc=1,argv[0]=”a.out”

运行的程序的文件名,也占用一个参数位置,也就是说argv数组中的第一个单元指向的字符串总是可执行程序的名字,以后的单元指向的字符串依次是程序调用时的参数。这个赋值过程是操作系统完成的,只需要拿来用就可以了。

4、在命令行参数的提交中,系统会自动给指针数组后加上一个NULL,所以for(i=0;i<argc;i++)这句也可以换成while(*argv!=NULL)int main(intargc)省略其它参数的定义也是可以的,这样运行时候argc就直接返回参数个数,而不返回其它。运行命令行参数带有char*argv[]的时候,如果输入参数带有空格,应该用双引号括起来。



#include "stdio.h"
void main()
{
int a[10];
printf("Input 10 numbers!");
printf("\n");
//数组放入10个数
for(int i=0; i<10; i++)
{
scanf("%d",&a[i]);
}
printf("The result:");

for(i=9; i>0; i--)//冒泡算法排序
{
for(int j=0; j<i; j++)
{
if(a[j] > a[j+1])
{
int temp = a[j];
a[j] = a[j+1];
a[j+1] = temp;
}
}
}
//把结果打印出来。
for(i=0; i<10; i++)
{
printf("%5d",a[i]);
}
printf("\n");
}

想输入多少个数据都可以自己定义,如果不需要,把n改为10就可以了
#include <stdio.h>
#include <stdlib.h>

void main()
{
int i,j,t,n,a[100];
int *p;
printf("请输入n=:");
scanf("%d",&n);
for(i=0;i<n;i++)
scanf("%d",&a[i]);
p=a;
for(i=0;i<n;i++)
{ /* 冒泡法排序 */
for(j=i;j<n;j++)
{
if(*(p+i)<*(p+j))
{
t=*(p+i); /* 交换a[i]和a[j] */
*(p+i)=*(p+j);
*(p+j)=t;
}
}
}
printf("排序后为:\n");
for(i=0;i<n;i++)
printf("%5d",a[i]);
printf("\n");
system("pause");
}

伺候化工厂

c语言高手帮忙:从键盘输入10个整数。用选择法或冒泡法将它们从小到大的顺序排序,并以此顺序输出。~

#include
main()
{
int s[10],t,i,j,x;
printf("input 10 numbers:
");
for(t=0;t<10;t++)
scanf("%d",&s[t]);
for(i=0;i<9;i++)
for(j=0;j<9-i;j++)
if(s[j]>s[j+1])
{t=s[j];s[j]=s[j+1];s[j+1]=t;}
printf("the result is:
");
for(j=0;j<10;j++)
printf("%d",s[j]);
printf("
");
}

#include
void main()
{
int i,j;
float a[10],t;
printf("请输入十个数字");
for(i=0;i<10;i++)
{
scanf("%f",&a[i]);
}
for(j=0;j<10;j++)
{
for(i=0;i<10-1;i++)
{
if(a[i]>a[i+1])
{
t=a[i];
a[i]=a[i+1];
a[i+1]=t;
}
}
}
for(i=0;i<10;i++)
{
printf("%f",a[i]);
printf(" ");
}
}====

C语言题目: 用冒泡法对任意输入的10个整数由小到大的顺序排序
答:2、定义变量类型。3、用一个for语句遍历整个数组。4、引入一个子函数,该子函数的作用是调整数组元素的顺序,使之由小到大排列。5、最后通过for函数一次输出调整后的数组元素。6、介绍一下子函数的实现语句,首先定义子函数。7、定义变量类型。8、该子函数实现顺序的调整。9、编译,执行即可。

C语言:从键盘上输入10个整数,将其保存到数组中,并按升序排列。_百度知 ...
答:源程序代码以及算法解释如下:define _CRT_SECURE_NO_WARNINGS include<stdio.h> int main(){ int i, j;//定义循环变量 int M_num;//定义中间变量 const int N = 10;//定义数组元素个数 int number[N];//定义两个数组 printf("请输入10个数组元素:\n");//文字提示 for (i = 0; i ...

c语言中用冒泡排序法排列任意输入的10个数,用程序输出排列的具体过程...
答://回答补充,晕,原来是这样的过程,我把以前的过程删除了,下面:include <stdio.h> define N 10 int main(){ int nArray[N];int i=0,n=1;printf("请输入数组数据:\n");for(i=0;i<N;i++){ scanf("%d",&nArray[i]);} printf("原始数据为:\n");for(i=0;i<N;i++){ pr...

c语言编程题:分别用冒泡法和选择法对输入的10个整数由大到小排序_百度...
答:include <stdio.h> void maopao(int *a){ int temp=0;for(int i=0;i<10-1;++i)//只需要冒泡9个数最后一个就已经有序了 for(int j=0;j<10-i-1;++j)//j的取值需<10-i-1;为何-1,if(a[j]<a[j+1]){ temp=a[j];a[j]=a[j+1];a[j+1]=temp;} } void xuanze(...

功能是从键盘输入 10 个整数,要求用插入排序方法将它们 按从小到大的...
答:include <stdio.h> int main(){ int a[11];//数组长度为11 int n = 10, i, j, t;int x;printf("请输入10个整数:\n");for (i = 0; i < 10; i++)scanf("%d", &a[i]);for (i = 0; i < 10; i++)//用冒泡法将输入的十个数排列好 */ for (j = 0; j < 9 ...

用C语言写一个函数,用冒泡法对输入的10个字符按由小到大的顺序排列_百...
答:maopao(int a[],int num){ int i,j,temp;printf("\nmao pao pai xu\n");for(i=0;i<=num;i++)for(j=0;j<=num-1;j++)if(a[j]>a[j+1]){ temp=a[j+1];a[j+1]=a[j];a[j]=temp;} } 其接受的实参为一个数组和这个数组元素个数。全过程 include<stdio.h> void ...

用冒泡法对10个整数排序,10个数用scanf函数输入
答:include <stdio.h>#define N 10int main(){ int num[N]; int i,j,temp; for(i = 0; i < N; i ++) scanf("%d",num + i); for(i = 0; i < N - 1; i ++) { for(j = N - 1; j > i; j --) { if(num[j] < num[j - 1]) ...

C语言:采用冒泡排序方法,对10个数按由小到大的的顺序排序
答:代码如下(对10个整数进行升序排序):include<stdio.h> int main(){ int i,j,t,a[10]={5,4,8,3,6,9,7,222,64,88};//排序 for(i=1;i<10;i++)//外循环控制排序趟数,n个数排n-1趟 { for(j=0;j<10-1;j++)//内循环每趟比较的次数,第j趟比较n-i次 { if(a[j]>a...

C语言用冒泡法和选择法对10个数进行排序
答:选择排序算法C语言的实现 选择法排序原理:一次选定数组中的每一个数,记下当前位置并假设它是从当前位置开始后面数中的最小数min=i,从这个数的下一个数开始扫描直到最后一个数,并记录下最小数的位置min,扫描结束后如果min不等于i,说明假设错误,则交换min与i位置上数。 具体实现代码如下:include...

C语言编写函数用冒泡法对数组中10个整数由大到小排序,并在主函数中调用...
答:include <stdio.h> void fun(int *num){ int temp;for(int i=0; i<10; ++i)for(int j=0; j<10-i-1; ++j){ if(num[j]<num[j+1]){ temp=num[j];num[j]=num[j+1];num[j+1]=temp;} } } void main(){ int num[10]={3,2,4,1,5,6,4,3,9,8};fun(num);fo...