实验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);//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);//最开始定义的是普通数值而不是指针,因此不用加&
    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; //把i赋给最大值的下标
        if (a[i] < a [*min]) *min=i; //把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; //把i赋给最大值的下标
        if (a[i] < a [min]) min=i; //把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';          /*将字符串的最后一个字符定义为'\0'*/
    f(str,&a,&b,&c);
    printf("英文字符:%d\t数字字符:%d\t其他:%d\n",a,b,c);
    return 0;
}
void f(char *line,int *a,int *b,int *c)
{
    *a=0;
    *b=0;
    *c=0;
    while(*line!='\0'){           /*当字符运行到字符串结束符'\0'时结束循环*/
    if((*line>='a'&&*line<='z')||(*line>='A'&&*line<='Z'))
        (*a)++;
    else if(*line>='0'&&*line<='9')
        (*b)++;
    else
        (*c)++;
    line++;         /*调用下一个字符参与下一次运算*/
    }
}

3、编程判断输入的一串字符是否为“回文”。所谓“回文”,是指顺读和倒读都一样的字符串。如“XYZYX”和“xyzzyx”都是“回文”。要求使用指针变量判断字符串是否是回文。

 

//编程判断输入的一串字符是否为“回文”。所谓“回文”,是指顺读和倒读都一样的字符串。如“XYZYX”和“xyzzyx”都是“回文”。要求使用指针变量判断字符串是否是回文。
#include<stdio.h>
int main(void)
{
    int i,n;
    int x,y;
    x=0,y=0;
    printf("enter n:");
    scanf("%d",&n);
    int a[80];
    for(i=1;i<n;i++)
    {
        printf("enter a[]:");
        scanf("%d",&a[i]);
    }
    for(x=0,y=n;x<y;x++,y++)
    {
        int *a,*b;//用指针判断是否为回文
        a=&a[x];
        b=&a[y];
        if(a!=b)
            break;
    }
    if(x>=y)
        printf("是回文");
    else
        printf("不是回文");
    return 0;
}

 

 

 

posted @ 2013-11-11 07:27  simple9495  阅读(231)  评论(0编辑  收藏  举报