c 语言程序报告
实验项目:
1, 指针基础及指针运算
2, 数据交换
3, 字符串反转及字符串连接
4, 数组元素奇偶排列
姓名: 吴波????? 实验地点: 第一教学楼 514 教室????? 实验时间: 6 月 12 日
一, 实验目的与要求:
1, 掌握指针的概念和定义方法
2, 掌握指针的操作符和指针的运算
3, 掌握指针与数组的关系
4, 掌握指针与字符串的关系
5, 熟悉指针作为函数的参数以及返回指针的函数
6, 了解函数指针
二, 实验内容
(一) 指针基础及指针运算实验练习 8.3.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 的地址, 并与上面的结果进行比较.
实验代码:
- #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 Addrss of c:%x,%x\n",p,&c);
- return 0;
- }
问题分析: 开始第一个 scanf("%d%f",&p,&q) 后面要求输入 p 和 q 的值然后根据理解我打的是 q,p 但运行之后发现不对, 在检查后才发现是我没有完全搞懂意思在思考及尝试后知道这里应该是输入的是 p,q.
程序运行图:
(二) 数据交换实验练习 8.3.2:
问题描述:
(1) 定义两个函数, 分别为 void swap1(int a,int b) 和 void swap2(int a,int b), 用于交换 a,b 的值.
(2) 从主函数中分别输入两个整形变量 a,b.
(3) 从主函数中分别调用上述两个交换函数, 并打印输出交换后 a,b 的结果.
实验代码:
- #include<stdio.h>
- void swap1(int x,int y);
- void swap2(int *x,int *y);
- 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);
- }
- 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;
- }
问题分析: 第二题较简单, 无问题.
程序运行图:
(三) 字符串反转及字符串连接实验练习 8.3.3:
问题描述:
(1) 定义两个字符指针, 通过 gets() 函数输入两个字符串.
(2) 定义一个函数 char reverse(char str), 通过指针移动方式将字符串反转.
(3)A 定义一个函数 char link(char str1,char *str2), 通过指针移动方式将两个字符串连接起来.
(4) 从主函数中分别调用上述函数, 输入字符串并打印输出结果.
实验代码:
- #include<stdio.h>
- char *reverse(char *str);
- char *link(char *strl,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("\nInput String1:");
- gets(str);
- printf("\nInput String2:");
- gets(str1);
- str2=link(str,str1);
- printf("\nLink string 1 and string 2:");
- 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='\0';
- return str1;
- }
问题分析: 开始指针相向移动不知道是什么意思卡了蛮久, 之后通过百度查询知相向移动的含义及使用解决了问题.
程序运行图:
(四) 数组元素奇偶排列实验练习 8.3.4:
问题描述:
(1) 定义一个整形一维数组, 任意输入数组的元素, 其中包含奇数和偶数.
(2) 定义一个函数, 实现将数组元素奇数在左, 偶数在右的排列.
(3) 在上诉定义的函数中, 不允许再增加新的数组.
(4) 从主函数中分别调用上述函数, 打印输出结果.
实验代码:
- #include<stdio.h>
- #define N 10
- void arrsort(int a[],int n);
- 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--;
- }
- }
问题分析: 与第三题较相似, 但开始一直运行不出来, 检查了好久才发现是我在 scanf("%d",&a[i]); 的 %d 后面多打了一个空格导致结果一直出不来, 其他无问题
程序运行图:
实验小结:
??????c 语言学到了指针这里我觉得我学的很吃力, 很多东西不能很好的去理解, 很多知识我不能搞懂, 觉得指针非常的绕, 很难学懂, 老师在课堂讲的东西很难当时就完全明白接受总是感觉似懂非懂的; 在这次实验过后虽然收获很大, 很多之前没搞懂的知识现在清楚了但是我觉得我指针还有很多知识还在似懂非懂的层面上, 还是仍然需要自己课后努力花时间去掌握.
来源: http://www.bubuko.com/infodetail-3092504.html