C语言从键盘输入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[]的时候,如果输入参数带有空格,应该用双引号括起来。

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2017-09-16
#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");
}
第2个回答  推荐于2017-09-16
想输入多少个数据都可以自己定义,如果不需要,把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");
}追问

我感觉和我的差不多啊 详细解释一下先!表示指针完全不会啊!

追答

冒泡排序,外面的那个for是控制循环的次数,里面的for是实际循环的条件,p=i;为什么每次要这样赋值?你表达的意思是把i的数值赋值给p,根本没有必要,而且还是错误的,后面又来个p++,完全混乱了,前面p的值都加咯,现在又加.后面输出排序后数组也错了,应该把*p改为*(p+i),我也是学指针的时候不懂,就用*(p+i)这种来避免错误

追问

我想问的你的冒泡排序法的内层的那个就是if()那个里面的指针的比较那部分怎么弄的!

本回答被提问者和网友采纳
第3个回答  2014-06-15
伺候化工厂
相似回答