• 实验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); 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); printf("数组b最大和最小元素下标是%d,%d ", max2, min2); return 0; } void findByPoint(int *a, int n, int *max, int *min) { int i; *max=*min=0; //max和min最初为空指针
    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 ", 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("请输入字符:
    ");
        ch=getchar();          //从键盘直接输入字符
        while(ch!='
    '){      
            str[i]=ch;
            i++;
            ch=getchar();
        }
        str[i]='';          //结束标志
        f(str,&a,&b,&c);
        printf("英文字符:%d
    数字字符:%d
    其他:%d
    ",a,b,c);
        return 0;
    }
    void f(char *line,int *a,int *b,int *c) //定义自定义函数
    {
        *a=0;                                //指针变量abc开始为空指针
        *b=0;
        *c=0;
        while(*line!=''){         
        if((*line>='a'&&*line<='z')||(*line>='A'&&*line<='Z'))
            (*a)++;
        else if(*line>='0'&&*line<='9')
            (*b)++;
        else
            (*c)++;
        line++;         
        }
    }

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

    #include<stdio.h>
    #include<string.h>
    int main(void)
    {
    int i,m,flag;
    char str[80],*p;
    p=str;
    printf("请输入一个字符串:");
    gets_s(str);
    m=strlen(str);
    flag=0;
    for(i=0;i<m/2;i++)
        if(p[i]!=p[m-1-i]){
            flag=1;
            break;
        }
        if(flag==1)
            printf("No
    ");
        else
            printf("Yes
    ");
    }

     

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

    #include<stdio.h>
    #include<string.h>
    int main(void)
    {
        char str[80],*p,t;
        int i,j;
        p=str;
        printf("输入一个字符串:");
        gets(p);
        j=strlen(p)-3;
        for(i=0;i<3;i++,j++){
            t=str[i];
            str[i]=str[j];
            str[j]=t;
        }
        printf("变换后的结果为:");
        puts(p);
    }
  • 相关阅读:
    Vue 中的无状态组件
    如何在 Vue 中使用 JSX 以及使用它的原因
    webpack打包优化的四种方法(多进程打包,多进程压缩,资源 CDN,动态 polyfill)
    watch监听对象
    微信小程序动态设置图片大小
    Flutter的生命周期和路由
    两个字符串的编辑距离学习[转载]
    系统进化树怎么看[转载]
    感知机PLA算法实现[转载]
    余弦相似度计算[转载]
  • 原文地址:https://www.cnblogs.com/laurenliu1994/p/3417109.html
Copyright © 2020-2023  润新知