算法手记3

🦄个人主页 :修修修也

🎏所属专栏 :刷题

⚙️操作环境 :牛客网


目录

一.dd爱框框

题目详情:

题目思路:

解题代码:

二.除2!

题目详情:

题目思路:

解题代码:

结语


一.dd爱框框

牛客网题目链接(点击即可跳转):dd爱框框


题目详情:

本题详情如下图:


题目思路:

本题解题思路如下:

滑动窗口!双指针一个left,一个right,同向向后滑动即可.窗口大于x就缩紧left向后移动,窗口小于x就扩大right向后移动.注意,left的下标从0开始,输出位置时要加1,right表示的是和left的相对距离,所以输出时不用加1.思路图示如下:


解题代码:

本题解题代码如下:

cpp 复制代码
#include<iostream>
#include<vector>

using namespace std;
int main()
{
    //滑动窗口,同向双指针
    //输入数据
    int n,x;
    cin>>n>>x;
    vector<int> vi;
    vi.resize(n);
    for(int i=0;i<n;i++)
    {
        cin>>vi[i];
    }
    //开始解题
    int left=0,right=0;
    int min_left=0,min_right= n;
    int sum=0;
    while(left<n && right<n && left<=right)
    {
        if(sum<x)
        {
            //扩大窗口
            sum+=vi[right];
            right++;
        }
        else
        {
            //如果新窗口长度比老窗口小,就更新最小区间
            if((right-left) < (min_right-min_left))
            {
                min_right=right;
                min_left=left;
            }
            //缩小窗口
            sum-=vi[left];
            left++;
        }
    }
    
    cout<<min_left+1<<" "<<min_right;
    return 0;
}

二.除2!

牛客网题目链接(点击即可跳转):除2!


题目详情:

本题详情如下图:


题目思路:

本题解题思路如下:

一开始输入的时候把奇数直接加到sum里,偶数直接push进大根堆,后面循环k次(条件是堆不为空)把堆顶的数据除2,堆顶除2后还是偶数就继续push进堆,如果不是偶数就直接加进sum.循环完毕把堆里剩下的偶数加进sum后输出即可.


解题代码:

本题解题代码如下:

cpp 复制代码
#include<iostream>
#include<queue>
using namespace std;

int main()
{
    int n,k,tmp;
    long long sum;
    cin>>n>>k;
    priority_queue<int> pq;
    for(int i=0;i<n;i++)
    {
        cin>>tmp;
        if(tmp%2==0)
            pq.push(tmp);
        else
            sum+=tmp;
    }
    for(int i=0;i<k;i++)
    {
        if(pq.empty())
            break;
        tmp = pq.top()/2;
        pq.pop();
        if(tmp%2==0)
            pq.push(tmp);
        else
            sum+=tmp;
    }
    while(!pq.empty())
    {
        sum+=pq.top();
        pq.pop();
    }
    cout<<sum;
    return 0;
}

结语

说点啥好呢...这两道题都不难,主要是手生,一时半会就ac不出来,有思路可以,下次画个图可能会更直观明了一点.以及之前手撕的STL没想到还有漏网之鱼,后续有空记得补一篇优先级队列的使用说明手册哈.

相关推荐
ulias2122 分钟前
各种背包问题简述
数据结构·c++·算法·动态规划
m0_5704664112 分钟前
代码随想录算法训练营第二十八天 | 买卖股票的最佳实际、跳跃游戏、K次取反后最大化的数组和
java·开发语言·算法
吃着火锅x唱着歌18 分钟前
LeetCode 1537.最大得分
算法·leetcode·职场和发展
数模加油站18 分钟前
25高教社杯数模国赛【C题超高质量思路+可运行代码】第十弹
算法·数学建模·数模国赛·高教社杯全国大学生数学建模竞赛
ulias21232 分钟前
动态规划入门:从记忆化搜索到动态规划
算法·动态规划
山河君33 分钟前
webrtc之语音活动上——VAD能量检测原理以及源码详解
算法·音视频·webrtc·信号处理
THMAIL1 小时前
深度学习从入门到精通 - LSTM与GRU深度剖析:破解长序列记忆遗忘困境
人工智能·python·深度学习·算法·机器学习·逻辑回归·lstm
JuneXcy1 小时前
结构体简介
c语言·数据结构·算法
jiaway1 小时前
【C语言】第四课 指针与内存管理
c语言·开发语言·算法
励志不掉头发的内向程序员1 小时前
C++进阶——继承 (1)
开发语言·c++·学习