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); //自定义函数,指针变量是a,max,min,地址是&max1 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); //自定义函数,指针变量是a,max,min,地址是&max2 printf("数组b最大和最小元素下标是%d,%d\n", max2, min2); return 0; } void findByPoint(int *a, int n, int *max, int *min) { int i; *max=*min=0; for (i = 1; i < n; i++) { if (a[i] > a [*max])*max=i; //*max指的是max的值,把i的值给*max 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; //max是变量,i的值给max if (a[i] < a [min])min=i; //同上 } printf("数组b最大和最小元素下标是%d,%d\n", max, min); }
2、输入一行字符,要求用自定义的函数void f(char *line)统计和输出字符串中数字字符、英文字符和其他字符的个数。
程序运行结果
#include<stdio.h> void count(char*s,int*digit,int*letter,int*other) { *digit=*letter=*other=0; while(*s!='\0'){ if(*s>='0'&&*s<='9') //在0~9之间为数字字符 (*digit)++; else if((*s>='a'&&*s<='z')||(*s>='A'&&*s<='Z')) //在a~z或A~Z为英文字符 (*letter)++; else (*other)++; s++; } } int main() { int i=0,digit,letter,other; char ch,str[80]; printf("Enter charaters:");//输入提示 ch=getchar(); while(ch!='\n'){ str[i]=ch; i++; ch=getchar(); } str[i]='\0'; //将结束符'\0'存入数组 count(str,&digit,&letter,&other); //统计字符串中各字符的个数 printf("digit=%d letter=%d other=%d\n",digit,letter,other); //输出字符个数 return 0; }
3、编程判断输入的一串字符是否为“回文”。所谓“回文”,是指顺读和倒读都一样的字符串。如“XYZYX”和“xyzzyx”都是“回文”。要求使用指针变量判断字符串是否是回文。
#include<stdio.h> #include<string.h> void main() { char s[20]; char*p,*q; int len,flag; gets(s); len =strlen(s); p=s; q=s+len-1; flag=1; while(p<q) { if(*p==q*){ p++;q--; } else{ flag=0;break; } } if(flag)printf("YES\n"); else printf("No\n"); }
4、输入两个字符串s和t,主函数通过调用(自定义)子函数先将字符串s倒置,然后再连接到字符串t之后。要求子函数的定义为void StrRecCat(char *s,char *t),比如,先将字符串abc倒置、然后接到字符串def之后,输出结果为:defcba。