【笔试常见编程题03】统计回文、连续最大和、不要二、把字符串转换成整数

在这里插入图片描述

1. 统计回文

“回文串”是一个正读和反读都一样的字符串,比如“level”或者“noon”等等就是回文串。花花非常喜欢这种拥有对称美的回文串,生日的时候她得到两个礼物分别是字符串A和字符串B。现在她非常好奇有没有办法将字符串B插入字符串A使产生的字符串是一个回文串。你接受花花的请求,帮助她寻找有多少种插入办法可以使新串是一个回文串。如果字符串B插入的位置不同就考虑为不一样的办法。

例如:
A = “aba”,B = “b”。这里有4种把B插入A的办法:

  • 在A的第一个字母之前: “baba” 不是回文
  • 在第一个字母‘a’之后: “abba” 是回文
  • 在字母‘b’之后: “abba” 是回文
  • 在第二个字母’a’之后 “abab” 不是回文

所以满足条件的答案为2
输入描述
每组输入数据共两行。 第一行为字符串A 第二行为字符串B 字符串长度均小于100且只包含小写字母
输出描述
输出一个数字,表示把字符串B插入字符串A之后构成一个回文串的方法数
示例 1
输入
aba
b
输出
2

思路1:暴力求解
在每个字符的前面插入另一个字符串
判断是否是回文
判断方法:前后双指针,指向头和尾
如果一样,一个++,一个- -

bool JudgePal(string s1) // 判断是否为回文
{int front = 0;int tail = s1.size() - 1;while (front < tail){if (s1[front] == s1[tail]){front++;tail--;}else return false;}return true;
}int main() {string s1, s2;getline(cin, s1);getline(cin, s2);int count = 0;for (int i = 0; i <= s1.size(); i++){string temp = s1;temp.insert(i, s2);if (JudgePal(temp))count++;}cout << count;return 0;
}

2. 连续最大和

一个数组有 N 个元素,求连续子数组的最大和。 例如:[-1,2,1],和最大的连续子数组为[2,1],其和为 3
输入描述
输入为两行。 第一行一个整数n(1 <= n <= 100000),表示一共有n个元素 第二行为n个数,即每个元素,每个整数都在32位int范围内。以空格分隔。
输出描述
所有连续子数组中和最大的值。
示例 1
输入
3
-1 2 1
输出
3

思路1:暴力求解

  1. 双循环求所有子数组的和
  2. 如果比int max大,更新max

时间复杂度 O ( N 2 ) O(N^2) O(N2)
在刷题软件上,如果数组元素过长
则会超出时间限制

int main() {size_t n;cin >> n;vector<int> v;v.resize(n);for (int i = 0; i < v.size(); i++) {cin >> v[i];}int max = v[0];for (int i = 1; i < v.size(); i++) {int temp = 0;for (int j = i; j < v.size(); j++){temp += v[j];if (temp > max)max = temp;}}cout << max;return 0;
}

思路2:dp

dp[i]是以数组下标为 i 的数作为结尾的最大子序列和,注意是以 i 为结尾
比如说现在有一个数组 {6,-3,-2,7,-15,1,2,2}
dp[2]就是以-2为结尾的,那么显然dp[2]的最大值就是1(6,-3,-2)
dp[3]要以7结尾,那么以7结尾的子序列最大和就是8(6,-3,-2,7)
求dp[i]有两种可能
第一种就是像上面的dp[3]一样,dp[2]求出来是1了,dp[2]加上array[3]比dp[2]大
把dp[2]加上array[3]赋给dp
第二种可能就是说如果dp[2]求出来是-100,dp[2]+array[3]是-93
这时候dp[2]反而拖垮了array[3],array[3]就是最大子序列,把array[3]赋给dp

时间复杂度 O ( N ) O(N) O(N)
空间复杂度 O ( 1 ) O(1) O(1)

int main()
{size_t n;cin >> n;vector<int> v;v.resize(n);for (int i = 0; i < v.size(); i++) {cin >> v[i];}int dp = v[0];int maxsum = v[0];for (int i = 1; i < v.size(); i++){dp = max(dp + v[i], v[i]);maxsum = max(dp, maxsum);}cout << maxsum;return 0;
}

3. 不要二

二货小易有一个W*H的网格盒子,网格的行编号为0H-1,网格的列编号为0W-1。每个格子至多可以放一块蛋糕,任意两块蛋糕的欧几里得距离不能等于2。
对于两个格子坐标(x1,y1),(x2,y2)的欧几里得距离为:
( (x1-x2) * (x1-x2) + (y1-y2) * (y1-y2) ) 的算术平方根
小易想知道最多可以放多少块蛋糕在网格盒子里。
输入描述
每组数组包含网格长宽W,H,用空格分割.(1 ≤ W、H ≤ 1000)
输出描述
输出一个最多可以放的蛋糕数
示例 1
输入
3 2
输出
4

思路1:
欧几里和距离就是最短直线距离
如果是求斜线距离涉及到勾股定理
比如:坐标(x2, y2)和(x1, y1)的距离
就是一条斜线距离
x1到x2的距离为1,y1到y2的距离也为1
1的平方加1的平方的算术平方根就是斜线距离
在这里插入图片描述
斜线距离是一定不为2的
所以只需要考虑横纵为2的距离不能放蛋糕
如图所示
横排第一和二个格子放蛋糕
第三和四就不能放蛋糕
竖排也是一样
在这里插入图片描述
第一排前两个格子是一定能放蛋糕的
第二排也是,放蛋糕是占先手的
也就是说放蛋糕的数量一定大于等于总格子的一半
如果横纵乘积模4为0,放蛋糕的数量就是横纵乘积除2
如果横纵乘积模4不为0,则需要看横和纵分别能不能整除2
如果能:放蛋糕数量 = 横纵乘积 + 2
如果不能:放蛋糕数量 = 横纵乘积 + 1

int main() {int W, H;cin >> W >> H;cout << W*H/2 + (!(W*H%4) ? 0 : (W % 2 == 0 && H % 2 == 0 ? 2 : 1));return 0;
}

4. 把字符串转换成整数

将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为 0 或者字符串不是一个合法的数值则返回 0
数据范围:字符串长度满足
进阶:空间复杂度 ,时间复杂度
注意:
①字符串中可能出现任意符号,出现除 +/- 以外符号时直接输出 0
②字符串中可能出现 +/- 且仅可能出现在字符串首位。
示例 1
输入
“+2147483647”
输出
2147483647
示例 2
输入
“1a33”
输出
0

思路1:

  1. 首先判断第一个字符
  2. 然后遍历字符串转换成数字加到num

转换出的整数可能超出整型能存储的最大值
需要判断一下
代码1从字符串最后往前取字符
加到num里面,代码有些难理解

class Solution {
public:int StrToInt(string str) {long long num = 0; int i = str.size() - 1;if ((str[0] < '0' || str[0] > '9') && (str[0] != '-' && str[0] != '+'))return 0;int power = 0;while (i >= 0){if (str[i] >= '0' && str[i] <= '9')num += (str[i--] - '0') * pow(10, power++);else if (i == 0 && (str[i] == '-' || str[i] == '+'))break;else if (num > 0x7fffffff || str[i] < '0' || str[i] > '9') // 字符串转换出的整型可能超出了整形能存储的最大值,所以需要判断一下return 0;}if (str[0] == '-')return -num;return num;  }
};

代码2从字符串第一个字符往后取字符
加到num里面

class Solution {
public:int StrToInt(string str) {long long num = 0; int i = 0;if (str[0] == '-' || str[0] == '+')i++;while (i < str.size()){if (str[i] >= '0' && str[i] <= '9')num = num * 10 + (str[i++] - '0');else if (num > 0x7fffffff || str[i] < '0' || str[i] > '9') // 字符串转换出的整型可能超出了整形能存储的最大值,所以需要判断一下return 0;}if (str[0] == '-')return -num;return num;  }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/654529.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mysql运维篇(三) MySQL备份与恢复

一路走来&#xff0c;所有遇到的人&#xff0c;帮助过我的、伤害过我的都是朋友&#xff0c;没有一个是敌人。如有侵权&#xff0c;请留言&#xff0c;我及时删除&#xff01; 一、物理备份与逻辑备份 1、物理备份&#xff1a;备份数据文件&#xff0c;转储数据库物理文件到某…

Web 开发 9:Django 框架基础

在本篇文章中&#xff0c;我们将深入探讨 Django 框架的基础知识。Django 是一个功能强大且流行的 Python Web 框架&#xff0c;它提供了一套完整的工具和功能&#xff0c;用于开发高效、可扩展的 Web 应用程序。 什么是 Django&#xff1f; Django 是一个基于 Python 的免费…

【qt】switchBtn

方法1 在qtdesigner中设置按钮图标的三个属性&#xff0c;normal off 、normal on和checkabletrue。 from PyQt5.QtWidgets import * from PyQt5.QtGui import * from PyQt5.QtCore import * from PyQt5 import uic from switchBtn import Ui_Dialogclass Test(QDialog, Ui_…

Python判断语句——if语句的基本格式

一、引言 在Python编程语言中&#xff0c;if语句是一种基本的控制流语句&#xff0c;用于根据特定条件执行不同的代码块。它的基本格式相对简单&#xff0c;使得Python代码清晰、易于阅读。下面&#xff0c;我们将深入探讨if语句的基本格式、用法和注意事项。 二、if语句的…

Date类型转成字符类型(String),字符类型(String)转成Date类型

效果图 注意&#xff1a;不建议使用YYYY-MM-dd HH:mm:ss格式&#xff0c;使用yyyy-MM-dd HH:mm:ss格式 import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Date;public class DateTimeDemo {public static void main(String[] args) thro…

群辉开启WebDav服务+cpolar内网穿透实现移动端ES文件浏览器远程访问本地NAS文件

文章目录 1. 安装启用WebDAV2. 安装cpolar3. 配置公网访问地址4. 公网测试连接5. 固定连接公网地址6. 使用固定地址测试连接 本文主要介绍如何在群辉中开启WebDav服务&#xff0c;并结合cpolar内网穿透工具生成的公网地址&#xff0c;通过移动客户端ES文件浏览器即可实现移动设…

电路笔记 :MOS场效应晶体管+红外遥控+AMS1117 电源模块

三极管&#xff08;BJT&#xff0c;Bipolar Junction Transistor&#xff09;和 MOSFET&#xff08;Metal-Oxide-Semiconductor Field-Effect Transistor&#xff09;是两种不同类型的晶体管&#xff0c;它们在工作原理、性能特性和应用方面有一些重要的区别。 结构和工作原理…

大模型学习笔记一:大模型应开发基础(模型归类选型、安全因素选型、)

文章目录 一、大模型一些概念介绍二、市面上大模型对比三、大模型使用安全选型四、使用大模型的方式&#xff08;一问一答、Agent Function Calling、RAG、Fine-tuning五、大模型使用路线九、补充说明1&#xff09;注意力机制讲解 一、大模型一些概念介绍 1&#xff09;产品和大…

时序预测 | Python基于Multihead-Attention-TCN-LSTM的时间序列预测

目录 效果一览基本介绍程序设计参考资料 效果一览 基本介绍 时序预测 | Python基于Multihead-Attention-TCN-LSTM的时间序列预测 Multihead-Attention-TCN-LSTM&#xff08;多头注意力-TCN-LSTM&#xff09;是一种结合了多个注意力机制、时序卷积网络&#xff08;TCN&#xff0…

Windows下EDK2快速搭建(详细)过程总结附软件包地址

目录 简介一、软件包下载安装VS2019下载NASM安下载LLVM/CLANG下载IASL下载安装Python安装OpenSSL下载EDK2 二、设置环境变量新增python系统变量新增NASM系统变量 三、编译3.1 在edk2目录直接输入cmd3.2 在cmd目录输入&#xff1a;edksetup.bat3.3 打开edk2编译窗口3.4 确认编译…

awk命令使用方法

简介 awk 是一种强大的文本处理工具&#xff0c;可以用于处理结构化的文本数据。它可以根据指定的模式和动作来筛选、处理和格式化文本。 下面是一些常见的 awk 命令使用方法。 详细介绍 基本语法&#xff1a; awk pattern { action } filename其中&#xff0c;pattern 是用…

微软 Power Apps Canvas App 画布应用将上传的附件转化为base64编码操作

微软 Power Apps Canvas App 画布应用将上传的附件结合Power Automate转化为base64编码操作 在使用canvas app的过程中&#xff0c;我们有时需要将上传的文件转换为base64存入数据库或者&#xff0c;调用外部接口传参&#xff0c;那么看下如何将文件转化为base64编码格式。 首先…

【数据分析】numpy基础第三天

前言 本文只会讲解最常用的加、减、乘、除&#xff0c;点乘&#xff08;或叫矩阵乘法&#xff09;、还有广播机制。 本文代码 链接提取码&#xff1a;1024 第1部分&#xff1a;基础数学计算 使用NumPy进行基本的数学运算是十分直观和简单的。下面我们将展示一些基本的加、…

笨蛋总结JVM

笨蛋总结JVM 由于Java语言将自己的内存控制权交给了虚拟机&#xff0c;所以需要了解虚拟机的运行机制 &#xff08;主要用于回顾JVM&#xff09; 笨蛋总结JVM 笨蛋总结JVM1.运行时数据区域线程私有区域程序计数器Java虚拟机栈本地方法栈 线程共享区域堆方法区 1.2程序计数器…

键盘上Ins键的作用

前几天编写文档时&#xff0c;发现一个问题&#xff1a;插入内容时&#xff0c;输入的字符将会覆盖光标位置后的字符。原来是按到了键盘上的 Ins键&#xff0c;解决方法是&#xff1a;再按一次 Ins键&#xff08;Ins键如果独立作为一键时&#xff0c;否则使用 “Fn Ins”组合键…

Sphinx的原理详解和使用

一、Sphinx介绍 1.1 简介 Sphinx是由俄罗斯人Andrew Aksyonoff开发的一个全文检索引擎。意图为其他应用提供高速、低空间占用、高结果 相关度的全文搜索功能。Sphinx可以非常容易的与SQL数据库和脚本语言集成。当前系统内置MySQL和PostgreSQL 数据库数据源的支持&#xff0c;也…

限时回归!!!3D版《空洞骑士》!!!

空洞骑士是一款基于横板平台跳跃的传统风格2D动作冒险游戏。庞大的游戏世界交错相通&#xff0c;玩家控制小虫子去探索幽深黑暗的洞穴&#xff0c;成为了一代人茶余饭后的惦念&#xff0c;深受广大玩家们的喜爱。 这类平台跳跃游戏一般是游戏开发初学者以及独立游戏开发者们比…

【DRAM存储器十八】DDR3介绍

&#x1f449;个人主页&#xff1a;highman110 &#x1f449;作者简介&#xff1a;一名硬件工程师&#xff0c;持续学习&#xff0c;不断记录&#xff0c;保持思考&#xff0c;输出干货内容 参考资料&#xff1a;《镁光DDR3数据手册》 、《JESD79-3E》 最近忙于工作&#xff0…

Linux使用匿名管道实现进程池得以高效通信

&#x1f3ac;慕斯主页&#xff1a;修仙—别有洞天 ♈️今日夜电波&#xff1a;Nonsense—Sabrina Carpenter 0:50━━━━━━️&#x1f49f;──────── 2:43 &#x1f504; ◀️ ⏸ ▶️ …

python基础四------完结(概念在下面,代码看不懂了再看)

# a_list [1,2,3,4,5] # # print(a_list)# 根据下标来删除列表中的元素 # 爬取的数据中 有个别的数据 是我们不想要的 那么我们就可以通过下标的方式来删除 # del a_list[2] # print(a_list)# b_list [1,2,3,4,5] # print(b_list) # pop是删除列表中的最后一个元素 # b_list.…