1. アドレス演算子 & を通じてアドレス値を取得します。
#include<stdio.h>
main()
{
int a,*p1;
p1=&a;
*p1=123;
printf("%d,%d\n",a,*p1);
scanf("%d",p1);
printf("%d,%d\n",a,*p1);
}
2. a、bを入力し、小さい方から大きい方へ順に出力します。
#include<stdio.h>
main()
{
int a,b,*p=&a,*q=&b,*t;
scanf("%d,%d",p,q);
if(*p<*q){
t=p;p=q;q=t;
}
printf("a=%d,b=%d\n",a,b);
printf("最大值=%d,最小值=%d\n",*p,*q);
}
3
3. ポインタメソッドを使用して配列要素にアクセスする
#include<stdio.h>
main()
{
int a[10],i,*p=a;
for(i=0;i<10;i++)
scanf("%d",p+i);
for(i=0;i<10;i++)
printf("%4d",*(p+i));
printf("\n");
}
4.キーボードから10個の整数を入力し、それらを配列aの山に入れ、配列内の要素の値を順番に出力します
#include<stdio.h>
main()
{
int *p,i,a[10];
p=&a[0];
for(i=0;i<10;i++)
scanf("%d",p++);
p=&a[0];
for(i=0;i<10;i++)
printf("%4d",*p++);
printf("\n");
}
5. 10桁の数字の最小値を前の位置に変更します
#include<stdio.h>
main()
{
int t,a[10],*p,*q;
for(p=a;p<=a+9;p++)
scanf("%d",p);
for(q=a,p=a+1;p<=a+9;p++)
if(*p<*q)q=p;
printf("最小值:%d\n",*q);
printf("最小值的位置:%d\n",q-a);
t=*a;*a=*q;*q=t;
printf("交换之后的10个数是:\n");
for(p=a;p<a+10;p++)
printf("%4d",*p);
printf("\n");
}
6. 2次元配列要素の最大値を求める
#include<stdio.h>
main()
{
int a[3][4]={
{5,1,-8,11},{26,-7,10,129},{2,18,7,16}},*p,max;
for(p=&a[0][0],max=*p;p<&a[0][0]+12;p++)
if(*p>max)max=*p;
printf("MAX=%d\n",max);
}
7. ポインタメソッドを使用して文字列をコピーします
#include<stdio.h>
main()
{
char a[80],b[80];
char *p1,*p2;
gets(a);
for(p1=a,p2=b;*p1!='\0';p1++,p2++)
*p2=*p1;
*p2='\0';
printf("字符串a中的内容:%s\n",a);
printf("字符串b中的内容:%s\n",b);
}
8.要素値を10要素の整数配列に逆順に格納して出力
#include<stdio.h>
void swap(int *x,int *y)
{
int t;
t=*x;
*x=*y;
*y=t;
}
main()
{
int a[10],i;
for(i=0;i<10;i++)
scanf("%d",&a[i]);
for(i=0;i<=4;i++)
swap(&a[i],&a[10-i-1]);
for(i=0;i<10;i++)
printf("%4d",a[i]);
printf("\n");
}
9. 関数を使用して、10 人の生徒の最高点、最低点、平均点を見つけます。
#include<stdio.h>
float fun(int *x,int n,int *p1,int *p2)
{
int i;
float s=0;
*p1=*p2=x[0];
for(i=0;i<n;i++)
{
s=s+x[i];
if(*p1<x[i]) *p1=x[i];
else if(*p2>x[i])*p2=x[i];
}
return s/n;
}
main()
{
int i,a[10],max,min;
float ave;
for(i=0;i<10;i++)
scanf("%d",&a[i]);
for(i=0;i<10;i++)
printf("%4d",a[i]);
ave=fun(a,10,&max,&min);
printf("\n 平均值=%6.2f,最大值=%d,最小值=%d\n",ave,max,min);
}
10. 10 個の数値の中の最大値を見つけます。これは、最大値を持つ要素のアドレスを返す関数を使用することで実現されます。
#include<stdio.h>
int *fun(int *x,int n)
{
int i,*y;
y=x;
for(i=1;i<n;i++)
if(*(x+i)>*y)y=x+i;
return y;
}
main()
{
int a[10],*p,i;
for(i=0;i<10;i++)
scanf("%d",&a[i]);
p=fun(a,10);
printf("最大值=%d\n",*p);
}