实验9 指针1
1、程序填空:下列程序在数组中同时查找最大元素和最小元素的下标,分别存放在 main()函数的max 和 min 变量中。要求:根据运行结果分析程序和填空,并注释说明填充依据。
#include <stdio.h> void findByPoint(int *, int, int *, int *); void find(int *a, int n, int max, int min); int main(void) { int max1=0, min1=0, a[]={5,3,7,9,2,0,4,1,6,8}; //定义十个数字的数组
findByPoint(a,10,&max1,&min1); printf("数组a最大和最小元素下标是%d,%d\n", max1, min1); int max2=0, min2=0,b[]={3,4,71,9,2,7,4,2,6,90}; find(b,10,max2,min2); printf("数组b最大和最小元素下标是%d,%d\n", max2, min2); return 0; } void findByPoint(int *a, int n, int *max, int *min) { int i; *max=*min=0; //max和min最初为空指针
for (i = 1; i < n; i++) { if (a[i] > a [*max])*max=i; if (a[i] < a [*min])*min=i; } } void find(int *a, int n, int max, int min) { int i; for (i = 1; i < n; i++) { if (a[i] > a [max]) max=i; //比较出最大值
if (a[i] < a [min])min=i; //比较出最小值
} printf("数组b最大和最小元素下标是%d,%d\n", max, min); }
2、输入一行字符,要求用自定义的函数void f(char *line)统计和输出字符串中数字字符、英文字符和其他字符的个数。
程序运行结果
#include<stdio.h> void f(char *line,int *a,int *b,int *c); int main(void) { int i=0,a,b,c; char ch,str[80]; printf("请输入字符:\n"); ch=getchar(); //从键盘直接输入字符 while(ch!='\n'){ str[i]=ch; i++; ch=getchar(); } str[i]='\0'; //结束标志 f(str,&a,&b,&c); printf("英文字符:%d\n数字字符:%d\n其他:%d\n",a,b,c); return 0; } void f(char *line,int *a,int *b,int *c) //定义自定义函数 { *a=0; //指针变量abc开始为空指针 *b=0; *c=0; while(*line!='\0'){ if((*line>='a'&&*line<='z')||(*line>='A'&&*line<='Z')) (*a)++; else if(*line>='0'&&*line<='9') (*b)++; else (*c)++; line++; } }
3、编程判断输入的一串字符是否为“回文”。所谓“回文”,是指顺读和倒读都一样的字符串。如“XYZYX”和“xyzzyx”都是“回文”。要求使用指针变量判断字符串是否是回文
#include<stdio.h> #include<string.h> int main(void) { int i,m,flag; char str[80],*p; p=str; printf("请输入一个字符串:"); gets_s(str); m=strlen(str); flag=0; for(i=0;i<m/2;i++) if(p[i]!=p[m-1-i]){ flag=1; break; } if(flag==1) printf("No\n"); else printf("Yes\n"); }
4、输入两个字符串s和t,主函数通过调用(自定义)子函数先将字符串s倒置,然后再连接到字符串t之后。要求子函数的定义为void StrRecCat(char *s,char *t),比如,先将字符串abc倒置、然后接到字符串def之后,输出结果为:defcba。
#include<stdio.h> #include<string.h> int main(void) { char str[80],*p,t; int i,j; p=str; printf("输入一个字符串:"); gets(p); j=strlen(p)-3; for(i=0;i<3;i++,j++){ t=str[i]; str[i]=str[j]; str[j]=t; } printf("变换后的结果为:"); puts(p); }