• 实验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,n,max,min*/
        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,n max,min*/
        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; /*把i的值给*max*/
            if (a[i] < a [*min])*min=i; /*把i的值给*min*/
        }
    }
    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的值给max*/
            if (a[i] < a [min])min=i; /*i的值给min*/
        }
        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')
    
                         (*digit)++;
    
                  else if((*s>='a' && *s<='z')||(*s>='A' && *s<='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
    ");
    
    }

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

  • 相关阅读:
    Django + uWSGI + Nginx 实现生产环境部署
    面试题(一)
    Python基础之路
    Tornado之实例和扩展
    Scrapy源码研究前戏
    算法之基本概念
    RedHat6.2系统安装ipvsadm+keepalived
    oracle11G 同时支持IPV4和IPV6配置
    redhat6.5 安装oracle11G
    python解析字体反爬
  • 原文地址:https://www.cnblogs.com/chaoyue0806/p/3411854.html
Copyright © 2020-2023  润新知