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); //自定义函数,指针变量是b,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 f(char*line,int*digit,int*letter,int*other) { *digit=*letter=*other=0; while(*line!='\0'){ if(*line>='0'&&*line<=9) (*digit)++; else if((*line>='a'&&*line<='z')||(*line>='A'&&*line<='Z')) (*letter)++; else (*other)++; line++; } } int main() { int i=0,digit,letter,other; char ch,str[80]; while(ch!='\n'){ str[i]=ch; i++; ch=getchar(); } str[i]='\0'; f(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。