[笔试训练](二十)058:经此一役小红所向无敌059:连续子数组最大和060:非对称之美

目录

058:经此一役小红所向无敌

059:连续子数组最大和

060:非对称之美


058:经此一役小红所向无敌

经此一役小红所向无敌 (nowcoder.com)

题目:

题解:

简单模拟:优化:尽量和先算出含有互砍的回合数,不要用下面的循环模拟每一个回合,时间复杂度会很大。

cpp 复制代码
while(h>0 && k>0)
    {
        ret+=a+b;
        k-=a;
        h-=b;
    }
cpp 复制代码
#include<iostream>
using namespace std;
long long a,h,b,k;
int main()
{
    cin>>a>>h>>b>>k;
    long long ret=0;
    //1.互砍多少回合
    long long n=min(h/b,k/a);
    ret+=n*a+n*b;
    
    //2.剩余血量
    h-=n*b;
    k-=n*a;
    
    //3.最后一轮是否都活着
    if(h>0 && k>0)
    {
        h-=b;
        k-=a;
        ret+=a+b;
    }
    
    //大招
    if(k>0)
    {
        ret+=10*b;
    }
    if(h>0)
    {
        ret+=10*a;
    }
    cout<<ret<<endl;
    
    return 0;
}

059:连续子数组最大和

连续子数组最大和_牛客题霸_牛客网 (nowcoder.com)

题目:

题解:

动态规划:

1.状态表示:dp[i],以 i 位置结尾时,所有子数组的最大和。

2.状态转移方程:dp[i]=max(dp[i-1]+a[i], a[i])

3.填表:初始化dp[0]=a[0], 向后遍历数组,同时维护记录连续子数组最大和。

cpp 复制代码
#include <iostream>
using namespace std;
const int N=2e5+10;
int n=0;
int a[N];

int main() 
{
    cin>>n;
    for(int i=0;i<n;i++)
    {
        cin>>a[i];
    }

    int dp[N];
    dp[0]=a[0];
    int ret=dp[0];
    for(int i=1;i<n;i++)
    {
        dp[i]=max(dp[i-1]+a[i],a[i]);
        ret=max(dp[i],ret);
    }
    cout<<ret<<endl;

    return 0;
}

060:非对称之美

非对称之美 (nowcoder.com)

题目:

题解:

找规律+贪心:

1.当一个字符串为回文字符串时,首或尾去掉一个字符则一定不为回文字符串,如:

2.当字符串中的字符均相同时,不符合上面的规律,不存在非回文子字符串。

总结:先判断字符串是否由相同字符组成(是则直接返回0),再判断本身是否为回文字符串,为回文字符串则返回n-1,不为则返回n。

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

int func()
{
    bool flag=false;
    int n=s.size();
    //1.字符串每个字符都一样
    for(int i=0;i<n;i++)
    {
        if(s[i]!=s[0])
        {
            flag=true;
        }
    }
    if(flag==false) return 0;
    
    //2.判断本身是否为回文字符串
    int left=0,right=n-1;
    while(left<right)
    {
        if(s[left]==s[right])
        {
            left++;
            right--;
        }
        else
        {
            flag=false;
            break;
        }
    }
    if(flag) return n-1;
    else return n;
}

int main()
{
    cin>>s;
    cout<<func()<<endl;
    
    return 0;
}
相关推荐
大胆飞猪2 小时前
递归、剪枝、回溯算法---全排列、子集问题(力扣.46,78)
算法·leetcode·剪枝
Kisorge4 小时前
【电机控制】基于STM32F103C8T6的二轮平衡车设计——LQR线性二次线控制器(算法篇)
stm32·嵌入式硬件·算法
铭哥的编程日记5 小时前
深入浅出蓝桥杯:算法基础概念与实战应用(二)基础算法(下)
算法·职场和发展·蓝桥杯
Swift社区5 小时前
LeetCode 421 - 数组中两个数的最大异或值
算法·leetcode·职场和发展
cici158745 小时前
基于高光谱成像和偏最小二乘法(PLS)的苹果糖度检测MATLAB实现
算法·matlab·最小二乘法
StarPrayers.6 小时前
自蒸馏学习方法
人工智能·算法·学习方法
大锦终6 小时前
【动规】背包问题
c++·算法·动态规划
智者知已应修善业7 小时前
【c语言蓝桥杯计算卡片题】2023-2-12
c语言·c++·经验分享·笔记·算法·蓝桥杯
hansang_IR7 小时前
【题解】洛谷 P2330 [SCOI2005] 繁忙的都市 [生成树]
c++·算法·最小生成树
Croa-vo7 小时前
PayPal OA 全流程复盘|题型体验 + 成绩反馈 + 通关经验
数据结构·经验分享·算法·面试·职场和发展