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

相关文章

MySQL更新某个字段拼接固定字符串的实现

《MySQL更新某个字段拼接固定字符串的实现》在MySQL中,我们经常需要对数据库中的某个字段进行更新操作,本文就来介绍一下MySQL更新某个字段拼接固定字符串的实现,感兴趣的可以了解一下... 目录1. 查看字段当前值2. 更新字段拼接固定字符串3. 验证更新结果mysql更新某个字段拼接固定字符串 -

Java Optional避免空指针异常的实现

《JavaOptional避免空指针异常的实现》空指针异常一直是困扰开发者的常见问题之一,本文主要介绍了JavaOptional避免空指针异常的实现,帮助开发者编写更健壮、可读性更高的代码,减少因... 目录一、Optional 概述二、Optional 的创建三、Optional 的常用方法四、Optio

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

golang获取当前时间、时间戳和时间字符串及它们之间的相互转换方法

《golang获取当前时间、时间戳和时间字符串及它们之间的相互转换方法》:本文主要介绍golang获取当前时间、时间戳和时间字符串及它们之间的相互转换,本文通过实例代码给大家介绍的非常详细,感兴趣... 目录1、获取当前时间2、获取当前时间戳3、获取当前时间的字符串格式4、它们之间的相互转化上篇文章给大家介

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

C#基础之委托详解(Delegate)

《C#基础之委托详解(Delegate)》:本文主要介绍C#基础之委托(Delegate),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 委托定义2. 委托实例化3. 多播委托(Multicast Delegates)4. 委托的用途事件处理回调函数LINQ