C程序设计实验报告

实验项目: 指针实验(第八章)

姓名: 赖倍仟 实验地点: 514物联网实验室 实验时间:2019年6月12日

一、实验目的和要求

(1)掌握指针的概念和定义方法。
(2)掌握指针的操作符和指针的运算。
(3)掌握指针与数组的关系。
(4)掌握指针与字符串的关系。
(5)熟悉指针作为函数的参数以及返回指针的函数。
(6)了解函数指针。

二、实验内容

(1)实验8.3.1指针基础及指针运算

1、问题描述:
(1)定义一个整型指针变量p,使它指向一个整型变量a,定义一个浮点型指针q,使它指向一个浮点型变量b,同时定义另外一个整型变量c并赋初值3。

(2)使用指针变量,调用scanf函数分别输入a和b的值。

(3)通过指针间接访问并输出a、b的值。
(4)按十六进制方式输出p、q的值以及a、b的地址。
(5)将p指向c,通过p间接访问c的值并输出。
(6)输出p的值及c的地址,并与上面的结果进行比较。
2、程序代码:

#include<stdio.h>
int main()
{
	int *p,a,c=3;
	float *q,b;
	p=&a;
	q=&b;
	printf("please input the value of a,b: ");
	scanf("%d,%f",p,q);
	printf("result: \n");
	printf("     %d, %f\n",a,b);
	printf("    %d, %f\n",*p,*q);
	printf("the address of a,b: %p,%p\n",&a,&b);
	printf("the address of a,b:%p,%p\n",p,q);
	p=&c;
	printf("c=%d\n ",*p);
	printf("the address of c : %x,%x\n",p,&c);
	return 0;
}

3、运行结果:

4、问题分析:
这一题是指针的基础,让我们更清晰地的知道指针以及指针所指向的值,在此题中p,q分别等于&a和&b,即a、b的地址。p,q等于a,b的值。

(2)实验8.3.2数据交换

1、问题描述:
(1)定义两个函数,分别为void swap1(int a,int b)和void swap2(inta.intb),用于交换a,b的值。

(2)从主函数中分别输入两个整型变量a、b。

(3)从主函数中分别调用上述两个交换函数,并打印输出交换后a、b的结果。
2、实验代码:

#include<stdio.h>
void swap1(int x,int y);
void swap2(int *x,int *y);
int main()
{
	int a,b;
	printf("please input a=: ");
	scanf("%d",&a);
	printf("\n       b=: ");
	scanf("%d",&b);
	swap1(a,b);
	printf("\nafter call swap1:a=%d b=%d\n",a,b);
	swap2(&a,&b);
	printf("\nafter call swap2: a=%d b=%d\n",a,b);
	return 0;
}
void swap1(int x,int y)
{
	int temp;
	temp=x;
	x=y;
	y=temp;
}
void swap2(int *x ,int*y)
{
	int temp;
	temp=*x;
	*x=*y;
	*y=temp;
}

3、运行结果:

4、问题分析:
在调用函数swap1时,a和b作为实际参数,但函数交换的是x和y这两个形式参数,所以并不会对a、b的值造成实际的影响。而调用swap2函数是形参x、y是指针变量,当a、b的地址即&a和&b传递过来时,两组变量拥有同样的地址,再交换他们的值,就会交换a、b的值了

(3)实验8.3.3字符串反转及字符串连接

1、问题描述:
(1)定义两个字符指针,通过gets()函数输入两个字符串。
(2)定义一个函数charreverse(charstr),通过指针移动方式将字符串反转。
(3)定义一个函数charlink(charstr1,char*str2),通过指针移动方式将两个字符串连接起来。
(4)从主函数中分别调用上述函数,输入字符串并打印输出结果。
2、实验代码:

#include<stdio.h>
char *reverse(char *str);
char *link(char *str1,char *str2);
int main()
{
	char str[30],str1[30],*str2;
	printf("input reversing character string: ");
	gets(str);
	str2=reverse(str);
	printf("\noutput reversed character string: ");
	puts(str2);
	printf("input string1: ");
	gets(str);
	printf("input string2: ");
	gets(str1);
	str2=link(str,str1);
	puts(str2);
	return 0;
}
char *reverse(char *str)
{
	char *p,*q,temp;
	p=str,q=str;
	while(*p!='\0')
	     p++;
	p--;
	while(q<p)
	{
		temp=*q;
		*q=*p;
		*p=temp;
		q++;
		p--;
	}
	return str;
}
char *link(char *str1,char *str2)
{
	char *p=str1,*q=str2;
	while(*p!='\0')
	     p++;
	while(*q!='\0')
	{
		*p=*q;
		p++;
		q++;
	}
	p--;
	return str1;
}

3、运行结果:

4、问题分析:
这一题要注意指针的位置还有指针的交换,还有指针指向的值位置调换。第一个函数将字符串反转,要用到一头一尾两个指针加上while循环来完成指针的相向运动和字符的交换。第二个函数需要一个指针移动到第一个字符串的的结束字符'\0'上,然后再将该指针指向第二个字符串,并依此做赋值处理,这样就把两个字符串连接起来了'\0'也被传递到了最后面。

(4)实验8.3.4数组元素奇偶排列

1、问题分析:
(1)定义一个整型一维数组,任意输入数组的元素,其中包含奇数和偶数。
(2)定义一个函数,实现将数组元素奇数在左,偶数在右的排列。
(3)在上述定义的函数中,不允许再增加新的数组。
(4)从主函数中分别调用上述函数,打印输出结果。
2、实验代码:

#include<stdio.h>
#define N 10
void arrsort(int a[],int n);
int main()
{
	int a[N],i;
	for(i=0;i<N;i++)
	   scanf("%d",&a[i]);
	arrsort(a,N);
	for(i=0;i<N;i++)
	printf("%d ",a[i]);
}
void arrsort(int a[],int n)
{
	int*p,*q,temp;
	p=a;
	q=a+n-1;
	while(p<q)
	{
		while(*p%2!=0)
		     p++;
		while(*q%2==0)
		     q--;
		if (p>q)
		   break;
		   temp=*p;
		   *p=*q;
		   *q=temp;
		   p++;
		   q--;
	}
}

3、运行结果:


4、问题分析:
首先是定义数组,输入任意的奇数和偶数。再定义一个函数,在函数中要定义两个指针,用p指针移动奇数,用q指针移动偶数。首先要做的是判断两指针的值里面的值是否为奇数和偶数,当p指针里的值为奇数时用p++将值放在数组的左边,同理,用q--将偶数放在右边。

三、实验小结

在编写大量的代码时,指针的使用将会很重要。虽然在我们现在运行的简单实验中,运用指针显得比较麻烦,但我们不应该因为指针比较难理解就不愿搞清楚指针,相反更应该让自己好好掌握它。我们要具有区分指针指向变量的值、指针变量、还有指针变量的地址。在指针与数组的关系中,各种地址描述和数组元素描述应该牢记,要加上自己的理解才不易混淆。