#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[]的时候,如果输入参数带有空格,应该用双引号括起来。
我感觉和我的差不多啊 详细解释一下先!表示指针完全不会啊!
追答冒泡排序,外面的那个for是控制循环的次数,里面的for是实际循环的条件,p=i;为什么每次要这样赋值?你表达的意思是把i的数值赋值给p,根本没有必要,而且还是错误的,后面又来个p++,完全混乱了,前面p的值都加咯,现在又加.后面输出排序后数组也错了,应该把*p改为*(p+i),我也是学指针的时候不懂,就用*(p+i)这种来避免错误
追问我想问的你的冒泡排序法的内层的那个就是if()那个里面的指针的比较那部分怎么弄的!
本回答被提问者和网友采纳