第十五届蓝桥杯 2024 C/C++组 合法密码

目录

题目:

题目描述:

题目链接:

思路:

substr函数:

思路详解:

代码:

代码详解;


题目:

题目描述:

题目链接:

P10906 蓝桥杯 2024 国 B 合法密码 - 洛谷

合法密码 - 蓝桥云课

思路:

substr函数:

substr函数的作用是从一个字符串里提取子字符串,string s1=str.substr(pos,count);

pos:子字符串起始的位置,默认值为 0,也就是从字符串的开头开始

count:要提取的字符数量

思路详解:

由题字符串的长度为8到16,所以第一层for循环遍历的是字符串的首位,第二层for循环是遍历长度为8到16字符串。在第二层for循环中先判断当前字符串的最后一位是否已经出界,若没有出界,那么就使用substr函数将遍历到的这个字符串提取出来。对于题目中对密码长度的要求已经在第二层for循环中处理了,现在就是对提取出的字符串判断满足必须包含至少 1 个数字字符和至少 1 个符号字符,单独定义一个check函数。至于答案就定义一个count进行计数即可

代码:

代码详解;

复制代码
#include<bits/stdc++.h>
using namespace std;

bool check(string s1)
{
	int a=0;           //定义a和b作为标记,标记是否有数字字符或符号字符 
	int b=0;
	for(int i=0;i<s1.size();i++)
	{
		if(s1[i]>='0'&&s1[i]<='9')
		{
			a=1;        //有数字字符出现就把a标记赋值为1 
		}
		if(s1[i]=='#')
		{
			b=1;        //有符号字符出现就把b标记赋值为1 
		}
	}
	if(a+b==2)
	{
		return true;    //数字字符和符号字符都出现过就return true; 
	}
	else
	{
		return false;  //注意这里记得return false;一开始没打这个发现结果总是755而不是400 
	}
}

int main()
{
	string str="kfdhtshmrw4nxg#f44ehlbn33ccto#mwfn2waebry#3qd1ubwyhcyuavuajb#vyecsycuzsmwp31ipzah#catatja3kaqbcss2th";
	int count=0;
	for(int i=0;i<str.size();i++)
	{
		for(int len=8;len<=16;len++)
		{
			if(i+len-1>str.size()) //遍历长度为8到16字符串时最后一位是str[i+len-1],判断是否出界 
			{
				break;
			}
			string s1=str.substr(i,len);  //substr函数,i是索引位置,len是提取的字符数 
			if(check(s1)==true)
			{
				count++;
			}
		}
	}
	cout<<count<<endl;
	return 0;
}
相关推荐
不吃土豆的马铃薯4 分钟前
C++ 正则表达式入门详解
linux·服务器·网络·数据库·c++·正则表达式
玖玥拾15 分钟前
C/C++ 数据结构(一)基础概念、线性表链表
c语言·数据结构·c++·链表
星恒随风16 分钟前
C++ 模板初阶:从泛型编程、函数模板到类模板,一篇打通基础概念
开发语言·c++·笔记·学习
郝学胜-神的一滴20 分钟前
Qt 高级开发 031:QListWidget图标布局实战
开发语言·c++·qt·程序人生·软件构建·用户界面
QiLinkOS23 分钟前
极客精神与商业思维的融合实践(3)
c语言·c++·人工智能·算法·开源协议
牛油果子哥q24 分钟前
队列(Queue)深度精讲,先进先出原理、顺序/链式/循环队列、STL queue底层、栈队列互模拟与面试考点全解
开发语言·c++·面试
暖阳华笺29 分钟前
【数据结构与算法】哈希专题
数据结构·c++·算法·leetcode·哈希算法
LuminousCPP33 分钟前
数据结构 - 单链表第二篇:单链表进阶操作
c语言·数据结构·笔记·链表
大白话_NOI35 分钟前
【洛谷 P1024 】[NOIP2001 提高组] 一元三次方程求解 - 详细分析与C++实现
c++·算法
随意起个昵称36 分钟前
区间dp-进阶题目1(进阶合并)
c++·算法·动态规划