【每日刷题】Day26

2024-04-28 04:36
文章标签 每日 刷题 day26

本文主要是介绍【每日刷题】Day26,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【每日刷题】Day26

🥕个人主页:开敲🍉

🔥所属专栏:每日刷题🍍

🌼文章目录🌼

1. [NOIP2008]笨小猴_牛客题霸_牛客网 (nowcoder.com)

2. 添加逗号_牛客题霸_牛客网 (nowcoder.com)

3. 简写单词_牛客题霸_牛客网 (nowcoder.com)

1. [NOIP2008]笨小猴_牛客题霸_牛客网 (nowcoder.com)

//思路:创建哈希表记录每个字母单词中每个字母出现的次数,算出出现次数最多max的以及出现次数最少的min,判断max-min是否为质数。

#include <stdio.h>

int main()

{

    int hash[123] = {0};

    char s[100] = {0};

    scanf("%s",s);

    int i = 0;

    int max = 0;

    int min = 100;

    while(s[i]>='a'&&s[i]<='z')//记录每个字母的出现次数

    {

        hash[s[i]]+=1;

        i++;

    }

    for(int j = 97;j<123;j++)

    {

        if(hash[j]>max)//找到最大值

        {

            max = hash[j];

        }

        if(hash[j]!=0&&hash[j]<min)//找到最小值

        {

            min = hash[j];

        }

    }

    if(max-min==1||max==min)//判断为1以及max==min的情况

    {

        printf("No Answer\n");

        printf("%d",0);

        return 0;

    }

    int flag = 1;

    for(int j = 2;j<(max-min);j++)//判断是否为质数

    {

        if((max-min)/j==0)//不是质数flag置为0

        {

            flag = 0;

        }

    }

    if(flag)//flag为1 说明是质数

    {

        printf("Lucky Word\n");

        printf("%d",max-min);

        return 0;

    }

    printf("No Answer\n");

    printf("%d",0);

    return 0;

}

2. 添加逗号_牛客题霸_牛客网 (nowcoder.com)

//思路:暴力解法。使用字符数组存放n的每一位,从个位开始,每三位数加一个' , '。需要注意的是,如果n为三位数,不需要加' , ',如果n为6位数,只需要加一个' , '。因此这里需要判断一下n的位数

#include <stdio.h>

int main()

{

    int n = 0;

    scanf("%d",&n);

    char s[20] = {0};

    int i = 0;

    int flag = 0;

    int num = 0;

    int m = n;

    int x = 0;

    while(m)

    {

        x++;

        if(x==4||x==7||x==10)//分别为加一个' , '、两个' , '、三个' , '的临界情况

        {

            num++;//num为' , '个数

        }

        m/=10;

    }

    while(n)

    {

        s[i++] = n%10+'0';

        flag++;

        if(flag==3&&num)//每三位加一个' , ',前提是num不能为0(也就是有' , '可加)

        {

            s[i++] = ',';

            num--;

            flag = 0;

        }

        n/=10;

    }

    i--;

    int count = 0;

    char ans[20] = {0};

    for(int j = i;j>=0;j--)//由于s存放是从n的个位开始存,因此这里需要倒转一下

    {

        ans[count++] = s[j];

    }

    printf("%s",ans);

}

3. 简写单词_牛客题霸_牛客网 (nowcoder.com)

//思路:需要改为大写存储的单词实际上就是复合词第一个单词的第一个字母以及' '后面第一个单词的第一个字母,因此在遍历复合词时,只需要将这些字母大写并存储即可。 

#include <stdio.h>

int main()

{

    char s[5000] = {0};

    gets(s);

    int i = 0;

    char ans[100] = {0};

    int j = 0;

    while(s[i]>='A'&&s[i]<='z'||s[i]==' ')

    {

        if(i==0)//复合词第一个单词第一个字母

        {

            if(s[0]>='a')

            {

                s[0]-=32;

            }

            ans[j++] = s[0];

        }

        if(s[i]==' ')//遇到空格存储后面遇到的第一个字母

        {

            i++;

            if(s[i]>='a')

            {

                s[i]-= 32;

            }

            ans[j++] = s[i];

        }

        i++;

    }

    printf("%s",ans);

}

这篇关于【每日刷题】Day26的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/942335

相关文章

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

每日一练7:简写单词(含链接)

1.链接 简写单词_牛客题霸_牛客网 2.题目 3.代码1(错误经验) #include <iostream>#include <string>using namespace std;int main() {string s;string ret;int count = 0;while(cin >> s)for(auto a : s){if(count == 0){if( a <=

【每日刷题】Day113

【每日刷题】Day113 🥕个人主页:开敲🍉 🔥所属专栏:每日刷题🍍 🌼文章目录🌼 1. 91. 解码方法 - 力扣(LeetCode) 2. LCR 098. 不同路径 - 力扣(LeetCode) 3. 63. 不同路径 II - 力扣(LeetCode) 1. 91. 解码方法 - 力扣(LeetCode) //思路:动态规划。 cl

代码训练营 Day26 | 47.排序II | 51. N-皇后 |

47.排序II 1.跟46题一样只不过加一个树层去重 class Solution(object):def backtracking(self,nums,path,result,used):# recursion stopif len(path) == len(nums):# collect our setresult.append(path[:])return for i in range(

hot100刷题第1-9题,三个专题哈希,双指针,滑动窗口

求满足条件的子数组,一般是前缀和、滑动窗口,经常结合哈希表; 区间操作元素,一般是前缀和、差分数组 数组有序,更大概率会用到二分搜索 目前已经掌握一些基本套路,重零刷起leetcode hot 100, 套路题按套路来,非套路题适当参考gpt解法。 一、梦开始的地方, 两数之和 class Solution:#注意要返回的是数组下标def twoSum(self, nums: Lis

力扣 739. 每日温度【经典单调栈题目】

1. 题目 理解题意: 1.1. 给一个温度集合, 要返回一个对应长度的结果集合, 这个结果集合里面的元素 i 是 当前 i 位置的元素的下一个更高温度的元素的位置和当前 i 位置的距离之差, 若是当前元素不存在下一个更高温度的元素, 则这个位置用0代替; 2. 思路 本题用单调栈来求解;单调栈就适用于来求当前元素左边或者右边第一个比当前元素大或者小的元素;【单调栈:让栈中的元素保持单调

代码随想录刷题day25丨491.递增子序列 ,46.全排列 ,47.全排列 II

代码随想录刷题day25丨491.递增子序列 ,46.全排列 ,47.全排列 II 1.题目 1.1递增子序列 题目链接:491. 非递减子序列 - 力扣(LeetCode) 视频讲解:回溯算法精讲,树层去重与树枝去重 | LeetCode:491.递增子序列_哔哩哔哩_bilibili 文档讲解:https://programmercarl.com/0491.%E9%80%92%E

每日一题——第八十一题

打印如下图案: #include<stdio.h>int main() {int i, j;char ch = 'A';for (i = 1; i < 5; i++, ch++){for (j = 0; j < 5 - i; j++){printf(" ");//控制空格输出}for (j = 1; j < 2 * i; j++)//条件j < 2 * i{printf("%c", ch

每日一题,力扣leetcode Hot100之238.除自身以外数组的乘积

乍一看这个题很简单,但是不能用除法,并且在O(N)时间复杂度完成或许有点难度。 考虑到不能用除法,如果我们要计算输出结果位置i的值,我们就要获取这个位置左边的乘积和右边的乘积,那么我新设立两个数组L和R。 对于L来说,由于表达的是位置i左边的数的乘积,那么L[0]=1,因为第一个数字左边没数那么为了不影响乘积初始值就设置为1,那么L[1]=L[0]*nums[0],那么L[i]=L[i-1