实验九
#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); //确定自定义函数findByPoint的元素
printf("数组a最大和最小元素下标是%d,%d\n", max1, min1);
int max2=0, min2=0,b[]={3,4,71,9,2,7,4,2,6,90};
find(a,10,max2,min2); //确定自定义函数find的元素
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; //找到最大值的下标
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);
}

//输入一行字符,要求用自定义的函数void f(char *line)统计和输出字符串中数字字符、英文字符和其他字符的个数
#include<stdio.h>
int main()
{
void f(char *line,int *digit,int *letter,int *other);
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';
f(str,&digit,&letter,&other);
printf("digit=%d letter=%d other=%d\n",digit,letter,other);
return 0;
}
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++;
}
}

//编程判断输入的一串字符是否为“回文”。所谓“回文”,是指顺读和倒读都一样的字符串。如“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");
}


浙公网安备 33010602011771号