预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共27页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

指针变量作为函数参数指针变量作为函数参数指针变量作为函数参数运行结果:指针变量作为函数参数#include<stdio.h> #include<math.h> intgetX(inta,intb,intc,float*x1,float*x2) { floatdata; data=(float)(b*b-4*a*c); if(data>0) { *x1=(float)(-b+sqrt(data)); *x2=(float)(-b-sqrt(data)); return2; } voidmain() { inta,b,c,count; floatx1,x2; scanf("%d%d%d",&a,&b,&c); count=getX(a,b,c,&x1,&x2); if(count==0) printf("wujie\n"); else printf("x1=%fx2=%f\n",x1,x2); } 运行结果:数组与指针数组元素表示方法数组与指针若p1与p2指向同一数组,p1-p2=两指针间元素个数(p1-p2)/d p1+p2无意义例inta[]={1,2,3,4,5,6,7,8,9,10},*p=a,i; 数组元素地址的正确表示:(A)&(a+1)(B)a++(C)&p(D)&p[i]例voidmain() {inta[]={5,8,7,6,2,7,3}; inty,*p=&a[1]; y=(*--p)++; printf(“%d”,y); printf(“%d”,a[0]); }main() {inti,*p,a[7]; p=a; for(i=0;i<7;i++) scanf("%d",p++); printf("\n"); p=a; for(i=0;i<7;i++,p++) printf("%d",*p); }数组与指针#include<stdio.h> voidsort(intn,int*p) {inti,j,t,*max; for(i=0;i<n;i++) {max=p; for(j=0;j<n-i;j++) {if(*(p+j)>*max) max=p+j; } t=*(p+j-1); *(p+j-1)=*max; *max=t; } }voidmain() { intn,a[10],i; scanf("%d",&n); for(i=0;i<n;i++) scanf("%d",&a[i]); sort(n,a); for(i=0;i<n;i++) printf("%d",a[i]); printf("\n"); }运行结果:voidsort(intn,int*a) {inti,j,t; int*max; for(j=n;j>0;j--) {max=a; for(i=0;i<j;i++) {if(*max<*(a+i)) max=a+i; } t=*max; *max=*(a+j-1); *(a+j-1)=t; } }intmain() {intn,i; inta[100]; scanf("%d",&n); for(i=0;i<n;i++) scanf("%d",&a[i]); sort(n,a); for(i=0;i<n;i++) printf("%d",a[i]); printf("\n"); return0; }