C程序设计实验报告
实验项目:
<1>8.3.1 指针基础及指针运算
<2>8.3.2 数据交换<3>8.3.3 字符串反转及字符串连接<4>8.3.4 数组元素奇偶排列姓名:石益涛 实验地点:教学楼514教室 实验时间:2019.6.12
一、实验目的与要求
<1>掌握指针的概念和定义方法。
<2>掌握指针的操作符和指针的运算。
<3>掌握指针与数组的关系。
<4>掌握指针与字符串的关系。
<5>熟悉指针作为函数的参数以及返回指针的函数。
<6>了解函数指针。
二、实验内容
实验练习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.实验代码:
/*8-1.c*/# includeint 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); }
3.运行结果:
4.问题分析:无实验练习2: 数据交换
1.问题的简单描述:
(1)定义两个函数,分别为voidswap1(inta,intb)和voidswap2(inta,intb),用于交换a,b的值。(2)从主函数中分别输入两个整型变量a、b。(3)从主函数中分别调用上述两个交换函数,并打印输出交换后a、b的结果。2.实验代码:# includevoid 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.问题分析:仅仅是填书上需要填的空,没有问题
实验练习3:字符串反转及字符串连接
1.问题的简单描述:
(1)定义两个字符指针,通过gets()函数输入两个字符串。(2)定义一个函数char reverse(char str),通过指针移动方式将字符串反转。(3)定义一个函数char link(char str1, char *str2),通过指针移动方式将两个字符串连接起来。(4)从主函数中分别调用上述函数,输入字符串并打印输出结果。2.实验代码:# includechar *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("\nInput String2: "); gets (str1); str2=link(str, str1); printf("\nLink String1 and String2: "); puts (str2); return 0; } char *reverse (char *str) { char *p, *q, temp; p=str, q=str; while (*p!='\0') p++; p--; while (q
3.运行结果:
4.问题分析:当q<p、指针做相向移动时,应该是“q++;p--”,我打的是“q--;p++”,后面都输出不了。
实验练习4: 数组元素奇偶排列
1.问题的简单描述:
(1)定义一个整型一维数组,任意输入数组的元素,其中包含奇数和偶数。(2)定义一个函数,实现将数组元素奇数在左,偶数在右的排列。(3)在上述定义的函数中,不允许再增加新的数组。(4)从主函数中分别调用上述函数,打印输出结果。2.实验代码:# include# define N 10void 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) break; temp=*p; *p=*q; *q=temp; p++;q--; }}
3.运行结果:
4.问题分析:这个题目没有很复杂,只需要知道判断奇数和偶数,将奇数往前移,偶数往后移就可以三、实验小结
1.可以通过指针间接访问并输出变量的值;
2.将实参传给形参时有两种方式:值传递与址传递; 3.使用指针作为形参时,实参必须是地址或数组名;