• 实验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
    ", 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
    ", 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
    ", 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!=''){
            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!='
    '){
            str[i]=ch;
            i++;
            ch=getchar();
        }
        str[i]='';  //将结束符''存入数组
        count(str,&digit,&letter,&other);  //统计字符串中各字符的个数
        printf("digit=%d letter=%d other=%d
    ",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
    ");
        else printf("No
    ");
    }

     4、输入两个字符串s和t,主函数通过调用(自定义)子函数先将字符串s倒置,然后再连接到字符串t之后。要求子函数的定义为void StrRecCat(char *s,char *t),比如,先将字符串abc倒置、然后接到字符串def之后,输出结果为:defcba。

  • 相关阅读:
    mysql 案例 ~ insert插入慢的场景
    mysql 原理 ~ DDL之在线DDL
    mongodb系列~ 索引详解
    mysql案例 ~ mysql磁盘分析与调优
    mysql 查询优化 ~ explain与索引失效
    mysql 原理 ~ 死锁问题
    mysql 原理 ~ 索引通说
    es集群数据库~基本安装
    mysql 案例 ~ pt-xtrabackup 使用
    mysql 原理 ~ 事务隔离机制
  • 原文地址:https://www.cnblogs.com/wuyanlong/p/3411769.html
Copyright © 2020-2023  润新知