强化训练:day9(添加逗号、跳台阶、扑克牌顺子)

文章目录

  • 前言
  • 1. 添加逗号
    • 1.1 题目描述
    • 2.2 解题思路
    • 2.3 代码实现
  • 2. 跳台阶
    • 2.1 题目描述
    • 2.2 解题思路
    • 2.3 代码实现
  • 3. 扑克牌顺子
    • 3.1 题目描述
    • 3.2 解题思路
    • 3.3 代码实现
  • 总结

前言

  1. 添加逗号
  2. 跳台阶
  3. 扑克牌顺子

1. 添加逗号

1.1 题目描述

在这里插入图片描述

2.2 解题思路

  我的写法是先进行逆置,然后再创建一个字符串,然后一个一个添加上去,每添加三个字符,就加上一个逗号,结束之后再进行逆置就可以了。(当然也可以直接逆序遍历,这样就不需要逆置了)

2.3 代码实现

#include <iostream>
using namespace std;
#include <string>
#include <algorithm>
int main() 
{string ret, num;cin >> num;reverse(num.begin(), num.end());int n = num.size();int k = 0;while (k < n) {if (k != 0 && k % 3 == 0)ret += ",";ret += num[k++];}reverse(ret.begin(), ret.end());cout << ret;return 0;
}

2. 跳台阶

2.1 题目描述

在这里插入图片描述

2.2 解题思路

  还是一道简单的dp问题,大概思路与之前写的最小花费爬楼梯相差无几。
  状态表示:dp[i] -> 到达 i 位置一共有多少跳法。每一个位置的跳法都来源于它前两个台阶,所以状态转移方程就是:dp[i] = dp[i-1] + dp[i-2]。
  还可以进行优化,那就是只用两个变量来保存一个台阶前两个台阶的各自的跳法,就像滚动数组一样,不断向前就可以了。如果不理解就写成上面的状态转移方程就行了。

2.3 代码实现

#include <iostream>
using namespace std;
int main() {int n = 0;cin >> n;int dp1 = 1, dp2 = 2;int ret = 0;if (n == 1) ret = 1;else if (n == 2) ret = 2;else {for (int i = 3; i <= n; i++) {ret = dp1 + dp2;dp1 = dp2;dp2 = ret;}}cout << ret;return 0;
}

3. 扑克牌顺子

3.1 题目描述

在这里插入图片描述

3.2 解题思路

  一开始我想了很多,写了半天写不出来,最后一看题解……
  其实这道题很简单,我们只要发现其中的规则,一下就出来了,那就是:最大的牌数和最小的牌数只差应该是等于4的(1,2,3,4,5),但是还有可能出现0的情况(3,4,5,0,0),因此所得的五张牌的最大与最小只差应该是小于等于4 但是其中不能有重复的牌(0可以重复噢),所以还需要判断(哈希)。
  我们只需要遍历一遍数组,找出最大与最小,看看它们的差值是否小于等于4就可以了,同时如果出现重复数字之间返回false即可。

3.3 代码实现

class Solution {
public:bool hash[14];bool IsContinuous(vector<int>& nums) {memset(hash, 0, sizeof hash);int maxVal = 0, minVal = 14;for(auto x : nums){if(x){if(hash[x]) return false;else{hash[x] = true;maxVal = max(maxVal, x);                minVal = min(minVal, x);                }}}return maxVal - minVal <= 4;}
};

总结

  今天的整体难度都比较简单,没什么可说的,大家多多练习吧。
  那么第九天的内容就到此结束了,如果大家发现有什么错误的地方,可以私信或者评论区指出喔。我会继续坚持训练的,希望能与大家共同进步!!!那么本期就到此结束,让我们下期再见!!觉得不错可以点个赞以示鼓励!

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

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

相关文章

Network Compression

听课&#xff08;李宏毅老师的&#xff09;笔记&#xff0c;方便梳理框架&#xff0c;以作复习之用。本节课主要讲了Network Compression&#xff0c;包括为什么要压缩&#xff0c;压缩的主要手段&#xff08;pruning,knowledge distillation,parameter quantization,architect…

简单记录下:Navicat 导出表结构至 Excel

首先我们需要通过sql语句查询出相关的表结构的结构 SELECT COLUMN_NAME AS 字段名称,COLUMN_TYPE AS 字段类型,IF(IS_NULLABLENO,否,是) AS 是否必填,COLUMN_COMMENT AS 注释FROM INFORMATION_SCHEMA.COLUMNSWHERE table_schema bs-gdsAND table_name sys_menu;查询的结构如下…

软件项目验收第三方测试报告如何获取

软件项目验收第三方测试报告是确保软件质量、安全性和稳定性的重要环节。对于企业和开发者来说&#xff0c;获取一份全面、专业的第三方测试报告&#xff0c;对于提升软件产品的竞争力和用户满意度至关重要。本文将介绍如何获取软件项目验收第三方测试报告&#xff0c;以及相关…

汇昌联信科技:拼多多电商的运营流程有哪些?

在当今互联网高速发展的时代&#xff0c;电商平台层出不穷&#xff0c;其中拼多多以其独特的团购模式和低价策略迅速崛起&#xff0c;成为众多消费者和商家的新宠。那么&#xff0c;拼多多电商的运营流程究竟包含哪些环节呢?接下来&#xff0c;我们将从商品上架、营销推广、订…

什么是ThreadLocal

1. 什么是ThreadLocal ThreadLocal 为每一个线程提供独立的局部变量&#xff0c;每个线程都拥有该变量的一个独立副本。 每个Thread里面都有一个ThrealLocal.ThreadLocalMap结构&#xff0c;里面由Entry数组组成。key是ThrealLocal&#xff0c;value是我们存的Object&#xff…

使用yarn/npm安装插件(涉及electron),总是报错证书错误或者ssl解析错误

同学们可以私信我加入学习群&#xff01; 正文开始 前言一、问题描述二、解决措施总结 前言 最近electron更新到了30大版本&#xff0c;里面更新的一个重大变化是主进程增加了 WebContentsView 和 BaseWindow&#xff0c;对窗口的控制会更加丝滑。 正好最近在做把文章或者视频…

2024-简单点-ultralytics库解析-data模块

data模块 overview布局\_\_init__.pyfrom .base import BaseDataset\_\_all__ annotator.pyaugment.pyclass BaseTransformclass Composeclass BaseMixTransformclass Mosaic静态方法更新label class MixUpRandomPerspectiveclass RandomHSV overview布局 从上往下解析 __init…

29、Qt使用上下文菜单(右键菜单)

说明&#xff1a;使用四种方式实现鼠标右击界面&#xff0c;显示出菜单&#xff0c;菜单上有两个动作&#xff0c;选择两个动作&#xff0c;分别打印“111”和“222”。 界面样式如下&#xff1a; 一、方法1&#xff1a;重写鼠标事件mousePressEvent .h中的代码如下&#xff…

C++——超简单登录项目

程序入口文件 #include <QtWidgets/QApplication> // 包含登录页面头文件 #include "DlgLogin.h"int main(int argc, char *argv[]) {QApplication a(argc, argv);// 程序入口// 调页面起来//DlgMain w;//w.show();// 换成登录页面DlgLogin w;w.show();return…

大数据可视化实验(四):Excel数据可视化

目录 一、实验目的... 1 二、实验环境... 1 三、实验内容... 1 1&#xff09;excel函数应用.. 1 2&#xff09;数据透视图绘制... 3 四、总结与心得体会... 5 一、实验目的 1&#xff09;掌握函数和公式的原理 2&#xff09;掌握在单元格或编辑栏中直接输入带函数的公式…

Weblogic未授权远程代码执行漏洞 (CVE-2023-21839)

1 漏洞概述 CVE-2023-21839是一个针对Oracle WebLogic Server的远程代码执行漏洞。WebLogic是美国Oracle公司出品的一个Java应用服务器&#xff0c;用于本地和云端开发、集成、部署和管理大型分布式Web应用、网络应用和数据库应用。该漏洞源于WebLogic IIOP/T3协议存在的缺陷&…

ATA-4315高压功率放大器在高频理疗仪驱动中的应用

现代社会&#xff0c;面对生活压力、工作压力&#xff0c;再加上不良的生活习惯&#xff0c;难免身体会出现这样或那样的问题&#xff0c;随着科技的发展&#xff0c;我们除了来到医院进行具体的治疗&#xff0c;一些可以用来辅助医生进行治疗的仪器设备也越来越多的应用到了临…