C语言程序实验报告Ⅶ
C语言程序实验报告Ⅶ
实验项目:C语言程序设计教程第八章指针实验8.3.1,8.3.2,8.3.3,8.3.3.4
姓名:陈?思杰?????实验地点:寝室?????实验时间:2020.06.02??
——————————————————————————————————————————————————————————
一、实验目的与要求??
??1.掌握指针的概念和定义方式
??2.掌握指针的操作符和指针的运算
??3.掌握指针与数组的关系
??4.掌握指针与字符串的关系
??5.熟悉指针作为函数参数及返回指针的函数
??6.了解函数指针
二、实验的内容??
??1.实验8.3.1指针基础及指针运算
问题的简单描述:指针的基本输入输出运算
实验代码:
/*sy8_1.c*/ #include<stdio.h> 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);//指针p,q输入a,b printf("Result:\n"); printf("\t%d %f\n",a,b); printf("\t%d %f\n",*p,*q);//指针p,q间接输出a,b 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",&c,p); }
问题分析:%p,%x用于输出十六进制的地址值
??2.实验8.3.2数据交换
问题的简单描述:
实验代码:
/*sy8_2.c*/ #include<stdio.h> void swap1(int x,int y); void swap2(int *x,int *y); int main() { int a,b; printf("Pleale Input \na=:"); scanf("%d",&a); printf("b=:"); scanf("%d",&b); swap1(a,b); printf("After Call swap1:a=%d b=%d",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.实验8.3.3字符串反转与字符串连接
问题的简单描述:
实验代码:
/*sy8_ 3.c */ #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("Output Reversed Character String: "); puts(str2); printf("Input String1: "); gets(str); printf("Input String2: "); gets(str1); str2=link(str,str1) ;//链接 printf("Link 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<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; q++; p++; } *p=‘\0‘; return str1; }
问题分析:
??4.实验8.3.4数组元素奇偶排列
问题的简单描述:
实验代码:
/*sy8_ 4.c */ #include<stdio.h> #define N 10 void arrsort(int a[],int n); main() { int a[N],i; printf("输入: "); for(i=0;i<N;i++) scanf("%d",&a[i]); arrsort(a,N); printf("输入: "); 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--; } }
问题分析: