笔试强训Day16 字符串 基础算法 双指针

2024-05-07 10:12

本文主要是介绍笔试强训Day16 字符串 基础算法 双指针,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

QR6 字符串替换

题目链接:字符串替换_牛客题霸_牛客网 (nowcoder.com)

思路:简单的字符串操作。

AC code:

class StringFormat 
{
public:string formatString(string A, int n, vector<char> arg, int m) {string ans;int pos = 0;for(int i = 0; i < A.size(); i ++){if(A[i] == '%'){ans += arg[pos++];i++;continue;}ans += A[i];}for(; pos < arg.size(); pos++)ans += arg[pos];return ans;}
};

[编程题]神奇数

题目链接:神奇数_牛客笔试题_牛客网 (nowcoder.com)

思路:

AC了没写个位数的情况, 注意next_permutation的返回值,若字典序没变大,则会返回0,

比如91 如果写dowhile循环的话 91 变成 19 会返回0 没法继续循环 ,加个特判即可。

AC code:

#include <iostream>
#include<string>
#include<algorithm>
using namespace std;
int n, m;
int ans;
string a;bool check(int x) {if(x < 2) return 0;for (int i = 2; i <= x / i; i ++)if (x % i == 0)return 0;return 1;
}int main() {cin >> n >> m;for (int i = n; i <= m; i ++) {a = to_string(i);int cnt = 0;while (1) {if (cnt == 2) break;if (a[0] != '0') {int x = (a[0] - '0') * 10 + a[1] - '0';if (check(x)) {//cout << i << ' ';ans++;break;}}if (!next_permutation(a.begin(), a.end()))cnt++;}}cout << ans << endl;return 0;
}

HJ63 DNA序列

题目链接:DNA序列_牛客题霸_牛客网 (nowcoder.com)

思路:

题目中求 G 和 C 在字符串的比例 双指针暴力即可。

AC code:

#include <bits/stdc++.h>
using namespace std;
int main()
{string s, res = "";int n, ans = -1;cin >> s >> n;for (int i = 0; i < s.size(); i++){int cnt = 0;string tmp = "";for (int j = i; j < s.size() && j < i + n; j++){tmp += s[j];if (s[j] == 'G' || s[j] == 'C') cnt++;}if (cnt > ans) res = tmp, ans = cnt;}cout << res << endl;
}

这篇关于笔试强训Day16 字符串 基础算法 双指针的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

C#从XmlDocument提取完整字符串的方法

《C#从XmlDocument提取完整字符串的方法》文章介绍了两种生成格式化XML字符串的方法,方法一使用`XmlDocument`的`OuterXml`属性,但输出的XML字符串不带格式,可读性差,... 方法1:通过XMLDocument的OuterXml属性,见XmlDocument类该方法获得的xm

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

python修改字符串值的三种方法

《python修改字符串值的三种方法》本文主要介绍了python修改字符串值的三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录第一种方法:第二种方法:第三种方法:在python中,字符串对象是不可变类型,所以我们没办法直接

MySQL中my.ini文件的基础配置和优化配置方式

《MySQL中my.ini文件的基础配置和优化配置方式》文章讨论了数据库异步同步的优化思路,包括三个主要方面:幂等性、时序和延迟,作者还分享了MySQL配置文件的优化经验,并鼓励读者提供支持... 目录mysql my.ini文件的配置和优化配置优化思路MySQL配置文件优化总结MySQL my.ini文件

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

C#中字符串分割的多种方式

《C#中字符串分割的多种方式》在C#编程语言中,字符串处理是日常开发中不可或缺的一部分,字符串分割是处理文本数据时常用的操作,它允许我们将一个长字符串分解成多个子字符串,本文给大家介绍了C#中字符串分... 目录1. 使用 string.Split2. 使用正则表达式 (Regex.Split)3. 使用

Java中JSON字符串反序列化(动态泛型)

《Java中JSON字符串反序列化(动态泛型)》文章讨论了在定时任务中使用反射调用目标对象时处理动态参数的问题,通过将方法参数存储为JSON字符串并进行反序列化,可以实现动态调用,然而,这种方式容易导... 需求:定时任务扫描,反射调用目标对象,但是,方法的传参不是固定的。方案一:将方法参数存成jsON字