指针指向数组
int a[10];
int *pa=a;//int *pa=&a[0];
指针中的重要等价关系:
pa+i 等价于 a+i 等价于 &a[i] 等价于 &pa[i]
*(pa+i) 等价于 *(a+i)等价于a[i]等价于pa[i]
遍历数组
int a[10];
int *pa=a;
for(;pa<a+10;pa++)
{
scanf("%d",pa);
//printf("%d",*pa);
}
第八章课后习题3
void main()
{
void input(int a[],int size);
void change(int a[],int size);
void output(int a[],int size);
int a[10];
input(a,10);
change(a,10);
output(a,10);
}
void input(int a[],int size)
{
int *p=a;
for(;a<p+size;a++)
{
scanf("%d",a);
}
}
void change(int a[],int size)
{
int t=0,*p=a;
void exchange(int *pa,int *pb);
for(;a<p+size;a++)
{
if(a[t]>a[i])
{
t=i;
}
}
if(t!=0)
{
exchange(&a[t],&a[0]);
}
t=0;
for(p=a;a<p+size;a++)
{
if(a[t]<a[i])
{
t=i;
}
}
if(t!=size-1)
{
exchange(&a[t],&a[size-1]);
}
}
void exchange(int *pa,int *pb)
{
int t;
t=*pa;
*pa=*pb;
*pb=t;
}
第八章课后习题4
#include “stdio.h”
void main()
{
void fun(int *pa,int *pb,int size,int m);
void output(int b[],int size);
int a[10]={1,2,3,4,5,6,7,8,9,10},b[10];
int m;
scanf("%d",&m);
fun(a,b,10,m);
output(b,10);
}
void fun(int *pa,int *pb,int size,int m)
{
int *a=pa,i;
pa=a+size-m;
for(i=0;i<m;i++)
{
*pb++=*pa++;
}
for(pa=a,i=0;i<size-m;i++)
{
*pb++=*pa++;
}
}
void output(int b[],int size)
{
int *p=b;
for(;b<p+size;b++)
{
printf("%d",*b);
}
}
数组元素逆置
#include “stdio.h”
void main()
{
void fun(int *pa,int size);
void output(int a[],int size);
int a[10]={1,2,3,4,5,6,7,8,9,10};
fun(a,10);
output(a,10);
}
void fun(int *pa,int size)
{
int *pb=pa+size-1,t;
for(;pa<pb;pa++,pb–)
{
t=*pa;
*pa=*pb;
*pb=t;
}
}
void output(int a[],int size)
{
int *p=a;
for(;a<p+size;a++)
{
printf("%d",*a);
}
}
c语言程序设计(18)
最新推荐文章于 2023-04-02 06:00:00 发布