笔试强训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

相关文章

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

Java中字符串转时间与时间转字符串的操作详解

《Java中字符串转时间与时间转字符串的操作详解》Java的java.time包提供了强大的日期和时间处理功能,通过DateTimeFormatter可以轻松地在日期时间对象和字符串之间进行转换,下面... 目录一、字符串转时间(一)使用预定义格式(二)自定义格式二、时间转字符串(一)使用预定义格式(二)自

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

Java字符串处理全解析(String、StringBuilder与StringBuffer)

《Java字符串处理全解析(String、StringBuilder与StringBuffer)》:本文主要介绍Java字符串处理全解析(String、StringBuilder与StringBu... 目录Java字符串处理全解析:String、StringBuilder与StringBuffer一、St

go 指针接收者和值接收者的区别小结

《go指针接收者和值接收者的区别小结》在Go语言中,值接收者和指针接收者是方法定义中的两种接收者类型,本文主要介绍了go指针接收者和值接收者的区别小结,文中通过示例代码介绍的非常详细,需要的朋友们下... 目录go 指针接收者和值接收者的区别易错点辨析go 指针接收者和值接收者的区别指针接收者和值接收者的

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

mysql的基础语句和外键查询及其语句详解(推荐)

《mysql的基础语句和外键查询及其语句详解(推荐)》:本文主要介绍mysql的基础语句和外键查询及其语句详解(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录一、mysql 基础语句1. 数据库操作 创建数据库2. 表操作 创建表3. CRUD 操作二、外键

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字