C++笔试强训day10

2024-04-28 21:12
文章标签 c++ 笔试 day10 强训

本文主要是介绍C++笔试强训day10,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1.最长回文字符串

2.买卖股票的最好时机(一)

3.过河卒


1.最长回文字符串

链接

一开始没认真看题目,直到提交了好几遍没过还是没去检查题目,一直检查代码逻辑,哎呦,难受了。

我以为是收尾字母相同就行了。

错误代码:

#include <algorithm>
class Solution {
public:int getLongestPalindrome(string A) {if (A.size() == 1 || A.size() == 0)return A.size();int len = 0;int r = A.size() - 1;for (int i = r; i >= 0; --i) {for (int j = 0; j <= r; ++j) {if (A[i] == A[j]) {int newlen = i - j + 1;len = max(len, newlen);break;}}}return len;}
};

正解:

双指针往该数的两边同时走,然后一直更新len就好了。

核心代码:

        for (int i = 1; i < A.size(); ++i) {l = i - 1;r = i + 1;while (l >= 0 && r < n) {if (A[l] == A[r]) {l--;r++;}else {break;}}len = max(len, r - l - 1);

细节:不确定是不是两数连一起相同,比如ababa 和 abaabc。

如果只用上述核心代码的话,就不能准确的计算出abaabc的长度了,因为他只是比他的前后。

要添加一个本身也计算的核心

        for (int i = 1; i < A.size(); ++i) {l = i - 1;r = i + 1;while (l >= 0 && r < n) {if (A[l] == A[r]) {l--;r++;}else {break;}}len = max(len, r - l - 1);l = i - 1;r = i;while (l >= 0 && r < n) {if (A[l] == A[r]) {l--;r++;}else {break;}}len = max(len, r - l - 1);

这样就能保证另一种也能过。

详细代码:

class Solution {
public:int getLongestPalindrome(string A) {int n = A.size();if (n < 2) {return n;}int len = 0;int l, r;for (int i = 1; i < A.size(); ++i) {l = i - 1;r = i + 1;while (l >= 0 && r < n) {if (A[l] == A[r]) {l--;r++;}else {break;}}len = max(len, r - l - 1);l = i - 1;r = i;while (l >= 0 && r < n) {if (A[l] == A[r]) {l--;r++;}else {break;}}len = max(len, r - l - 1);}return len;}
};

2.买卖股票的最好时机(一)

链接

我的一开始的解法是用队列存储一个pair<int, int>一个存值,一个存下标。

然后暴力枚举每个组合,最后肯定是超时了。

正解就是一边遍历数组,一边更新下标 i 之前的最小值Min,同时更新总值sum。

详细代码:

#include <iostream>
#include <vector>
using namespace std;int sum = 0;int main() {int n;cin >> n;vector<int> v(n);for (int i = 0; i < n; ++i){cin >> v[i];}int Min = v[0];for (int i = 1; i < n; ++i){if (v[i] - Min > sum){sum = v[i] - Min;}Min = min(Min, v[i]);}cout << sum << endl;return 0;
}

3.过河卒

链接

一道线性加约束条件dp问题。

细节:x1 != x,y2 != y,dp数组的初始化

处理好这些细节之后,解题就不容易出错。

详细代码:(我这里是将所有坐标挪动了1位,即起点在1,1;所以马的位置x,y也都要+=上一个数字1

#include <iostream>
using namespace std;int n, m, x, y; 
long long dp[30][30];
int main() 
{cin >> n >> m >> x >> y;x++, y++;dp[0][1] = 1;for(int i = 1; i <= n + 1; i++){for(int j = 1; j <= m + 1; j++){if(i != x && j != y && ((abs(i - x) + abs(j - y)) == 3) || (i == x && j == y))dp[i][j] = 0;elsedp[i][j] = dp[i - 1][j] + dp[i][j - 1];}}cout << dp[n + 1][m + 1] << endl;
}

这篇关于C++笔试强训day10的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符

C++中detach的作用、使用场景及注意事项

《C++中detach的作用、使用场景及注意事项》关于C++中的detach,它主要涉及多线程编程中的线程管理,理解detach的作用、使用场景以及注意事项,对于写出高效、安全的多线程程序至关重要,下... 目录一、什么是join()?它的作用是什么?类比一下:二、join()的作用总结三、join()怎么

C++中全局变量和局部变量的区别

《C++中全局变量和局部变量的区别》本文主要介绍了C++中全局变量和局部变量的区别,全局变量和局部变量在作用域和生命周期上有显著的区别,下面就来介绍一下,感兴趣的可以了解一下... 目录一、全局变量定义生命周期存储位置代码示例输出二、局部变量定义生命周期存储位置代码示例输出三、全局变量和局部变量的区别作用域

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被