题解 | 笨小猴

笨小猴

https://www.nowcoder.com/practice/17865bc2a75c4944a872ef709958c56e

#include <stdio.h>
int max(int arr[],int n)        //将存储对应字母个数的字符串整个传过来,n为字符串长度
{
    int max = 0;
    for (int i=0; i<n; i++)     //遍历26个字母,寻找最大值
    {
        if (max<=arr[i]) 
        {
            max = arr[i];       
        }    
    }
    return max;
}

int min(int arr[],int n)             //将存储对应字母个数的字符串整个传过来,n为字符串长度
{
    int min = 99;                    //由于要找出最小值,所以必须先将min初始化为大
    for (int i=0; i<n; i++) 
    {
        if (min>=arr[i]&&arr[i]!=0)  //在26个字母中可能有未出现的字母,所以我们需要将0排除
        {
            min = arr[i];       
        }    
    }
    return min;
}

void zhishu(int m)                   //质数的判断
{
    int n = 0;
    for (int i = 2; i<m; i++)        //质数需要排除1和他的自身作为因数,所以从2开始,从m(数字本身)停止
    {
        if (m%i==0) 
        {
            n++;                     //若出现因数,那么n就会变化
        }
          
    }
    if (n==0&&m!=0&&m!=1)            //特殊情况会出现m=0或1,直接判定为质数就好
    {
        printf("Lucky Word\n");      
        printf("%d",m);   
    }
    else 
    {
        printf("No Answer\n");
        printf("0");   
    }

}

int main() {
    char ch1[100];             //ch1用于存储键盘输入的字符串
    char ch2[100]= {'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z','\0'};                    //ch2初始化所有的小写字母,用于比对ch1中出现的字母
    int ch3[100]={0};          //ch3主要用来初始化下标0-25的对应字母a-z的位置,后续存储对应字母的数量
    scanf("%s",ch1);
   
    for (int i=0; ch1[i]!='\0'; i++)     //读出ch1中的所有字母
    {
        for (int j=0;ch2[j]!='\0';j++)   //每次读出ch1的字母后,丢进ch2进行比对
        {
            if (ch1[i]==ch2[j])          //如果相等
            {
                ch3[j]++;        //那么存储在ch3对应的位置上,注意ch2中字母的位置是j,那么ch3存在对应下标             
            }        
        }  
    }
    int max_word = max(ch3, 26);
    int min_word = min(ch3, 26);
    int gap = max_word - min_word;     //调用函数,没什么好说的
    zhishu(gap);
    return 0;
}

全部评论

相关推荐

双尔:你就写拥有ai开发经历,熟练运用提示词,优化ai,提高ai回答质量
点赞 评论 收藏
分享
12-04 16:18
已编辑
东华理工大学 前端工程师
面试官全程关摄像头1.自我介绍一下2.React和Vue哪个更熟悉一点3.你在之前那段实习经历中有没有什么技术性的突破(我只是实习了44天工作28天,我把我能说的都说了)4.你封装的哪个表单组件支不支持动态传值5.自己在实习阶段Vue3项目封装过hook吗6.hook有什么作用7.Vue2和Vue3的响应式区别(我说一个是proxy是拦截所有的底层操作,Object.defineProperty本身就是一个底层操作,有些东西拦截不了,比如数组的一些操作还有等等,面试官就说实在要拦截能不能拦截????我心想肯定不行呀,他的底层机制就不允许吧)8.pinia和vuex的区别(这个回答不出来是我太久没用了)9.pinia和zustand的区别,怎么选(直接给我干懵了)(我说react能用pinia吗&nbsp;&nbsp;他说要用的话也可以)10.渲染一万条数据,怎么解决页面卡顿问题(我说分页、监听滚轮动态加载,纯数据展示好像还可以用canvas画)(估计是没说虚拟表单,感觉不满意)11.type和interface的区别12.ts的泛型有哪些作用(我就说了一个结构相同但是类型不同的时候可以用,比如请求响应的接口,每次的data不同,这里能用一个泛型,他问我还有什么)13.你项目用的是React,如果让你再写一遍你会选择什么14.pnpm、npm、yarn的区别15.dependencies和devdependencies的区别总而言之太久没面试了,上一段实习的面试js问了很多。结果这次js一点没问,网络方面也没考,表现得很一般,但是知道自己的问题了&nbsp;&nbsp;好好准备,等待明天的影石360和周四的腾讯了&nbsp;&nbsp;加油!!!
解zj:大三的第一段面试居然是这样的结局
查看15道真题和解析
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务