热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

字符串中特定字符的移除方法

本文介绍如何从字符串中移除大写、小写、特殊、数字和非数字字符,并提供了多种编程语言的实现示例。
字符串中特定字符的移除方法

在处理文本数据时,有时需要对字符串进行清理,移除其中的大写、小写、特殊、数字和非数字字符。本文将详细介绍这一过程,并提供 C++、Java 和 Python 的代码实现。

问题描述

给定一个长度为 N 的字符串 str,任务是从该字符串中移除指定类型的字符,并输出修改后的结果。

示例

输入: str = "gfg fg 123 $%"
输出:
移除大写字符后: gfg123$%
移除小写字符后: GFG123$%
移除特殊字符后: GFGgfg123
移除数字字符后: GFGgfg$%
移除非数字字符后: 123

输入: str = "J@va12"
输出:
移除大写字符后: @va12
移除小写字符后: J@12
移除特殊字符后: Java12
移除数字字符后: J@va
移除非数字字符后: 12

方法一:逐字符遍历法

最简单的方法是遍历字符串中的每个字符,并根据其 ASCII 值判断是否需要移除:

  • 如果 ASCII 值在 [65, 90] 范围内,则为大写字符,跳过这些字符。
  • 如果 ASCII 值在 [97, 122] 范围内,则为小写字符,跳过这些字符。
  • 如果 ASCII 值在 [32, 47]、[58, 64]、[91, 96] 或 [123, 126] 范围内,则为特殊字符,跳过这些字符。
  • 如果 ASCII 值在 [48, 57] 范围内,则为数字字符,跳过这些字符。
  • 否则为非数字字符,跳过这些字符。

时间复杂度: O(N)
辅助空间: O(1)

方法二:正则表达式法

使用正则表达式可以更简洁地实现字符移除。以下是具体步骤:

  • 创建正则表达式来匹配需要移除的字符类型。
  • 编译正则表达式以创建模式对象。
  • 使用模式对象匹配字符串并替换匹配项为空字符串。

下面是 C++、Java 和 Python 的实现代码:

C++ 实现

#include 
#include
using namespace std;

string removingUpperCaseCharacters(string str) {
const regex pattern("[A-Z]");
return regex_replace(str, pattern, "");
}

string removingLowerCaseCharacters(string str) {
const regex pattern("[a-z]");
return regex_replace(str, pattern, "");
}

string removingSpecialCharacters(string str) {
const regex pattern("[^A-Za-z0-9]");
return regex_replace(str, pattern, "");
}

string removingNumericCharacters(string str) {
const regex pattern("[0-9]");
return regex_replace(str, pattern, "");
}

string removingNonNumericCharacters(string str) {
const regex pattern("[^0-9]");
return regex_replace(str, pattern, "");
}

int main() {
string str = "GFGgfg123$%";
cout <<"移除大写字符后: " < cout <<"移除小写字符后: " < cout <<"移除特殊字符后: " < cout <<"移除数字字符后: " < cout <<"移除非数字字符后: " < return 0;
}

Java 实现

import java.util.regex.Matcher;
import java.util.regex.Pattern;

class GFG {
public static String removingUpperCaseCharacters(String str) {
String regex = "[A-Z]";
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(str);
return matcher.replaceAll("");
}

public static String removingLowerCaseCharacters(String str) {
String regex = "[a-z]";
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(str);
return matcher.replaceAll("");
}

public static String removingSpecialCharacters(String str) {
String regex = "[^A-Za-z0-9]";
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(str);
return matcher.replaceAll("");
}

public static String removingNumericCharacters(String str) {
String regex = "[0-9]";
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(str);
return matcher.replaceAll("");
}

public static String removingNonNumericCharacters(String str) {
String regex = "[^0-9]";
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(str);
return matcher.replaceAll("");
}

public static void main(String[] args) {
String str = "GFGgfg123$%";
System.out.println("移除大写字符后: " + removingUpperCaseCharacters(str));
System.out.println("移除小写字符后: " + removingLowerCaseCharacters(str));
System.out.println("移除特殊字符后: " + removingSpecialCharacters(str));
System.out.println("移除数字字符后: " + removingNumericCharacters(str));
System.out.println("移除非数字字符后: " + removingNonNumericCharacters(str));
}
}

Python 实现

import re

def removingUpperCaseCharacters(s):
regex = "[A-Z]"
return re.sub(regex, "", s)

def removingLowerCaseCharacters(s):
regex = "[a-z]"
return re.sub(regex, "", s)

def removingSpecialCharacters(s):
regex = "[^A-Za-z0-9]"
return re.sub(regex, "", s)

def removingNumericCharacters(s):
regex = "[0-9]"
return re.sub(regex, "", s)

def removingNonNumericCharacters(s):
regex = "[^0-9]"
return re.sub(regex, "", s)

s = "GFGgfg123$%"
print("移除大写字符后:", removingUpperCaseCharacters(s))
print("移除小写字符后:", removingLowerCaseCharacters(s))
print("移除特殊字符后:", removingSpecialCharacters(s))
print("移除数字字符后:", removingNumericCharacters(s))
print("移除非数字字符后:", removingNonNumericCharacters(s))

推荐阅读
  • 深入解析SpringMVC核心组件:DispatcherServlet的工作原理
    本文详细探讨了SpringMVC的核心组件——DispatcherServlet的运作机制,旨在帮助有一定Java和Spring基础的开发人员理解HTTP请求是如何被映射到Controller并执行的。文章将解答以下问题:1. HTTP请求如何映射到Controller;2. Controller是如何被执行的。 ... [详细]
  • 在高并发需求的C++项目中,我们最初选择了JsonCpp进行JSON解析和序列化。然而,在处理大数据量时,JsonCpp频繁抛出异常,尤其是在多线程环境下问题更为突出。通过分析发现,旧版本的JsonCpp存在多线程安全性和性能瓶颈。经过评估,我们最终选择了RapidJSON作为替代方案,并实现了显著的性能提升。 ... [详细]
  • java文本编辑器,java文本编辑器设计思路
    java文本编辑器,java文本编辑器设计思路 ... [详细]
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • 深入解析动态代理模式:23种设计模式之三
    在设计模式中,动态代理模式是应用最为广泛的一种代理模式。它允许我们在运行时动态创建代理对象,并在调用方法时进行增强处理。本文将详细介绍动态代理的实现机制及其应用场景。 ... [详细]
  • 深入解析 Android IPC 中的 Messenger 机制
    本文详细介绍了 Android 中基于消息传递的进程间通信(IPC)机制——Messenger。通过实例和源码分析,帮助开发者更好地理解和使用这一高效的通信工具。 ... [详细]
  • 本文探讨了如何在Classic ASP中实现与PHP的hash_hmac('SHA256', $message, pack('H*', $secret))函数等效的哈希生成方法。通过分析不同实现方式及其产生的差异,提供了一种使用Microsoft .NET Framework的解决方案。 ... [详细]
  • 优化SQL Server批量数据插入存储过程的实现
    本文介绍了一种改进的SQL Server存储过程,用于生成批量插入语句。该方法不仅提高了性能,还支持单行和多行模式,适用于SQL Server 2005及以上版本。 ... [详细]
  • 本文将详细探讨 Java 中提供的不可变集合(如 `Collections.unmodifiableXXX`)和同步集合(如 `Collections.synchronizedXXX`)的实现原理及使用方法,帮助开发者更好地理解和应用这些工具。 ... [详细]
  • 本文详细探讨了Java中的ClassLoader类加载器的工作原理,包括其如何将class文件加载至JVM中,以及JVM启动时的动态加载策略。文章还介绍了JVM内置的三种类加载器及其工作方式,并解释了类加载器的继承关系和双亲委托机制。 ... [详细]
  • CentOS 7.6环境下Prometheus与Grafana的集成部署指南
    本文旨在提供一套详细的步骤,指导读者如何在CentOS 7.6操作系统上成功安装和配置Prometheus 2.17.1及Grafana 6.7.2-1,实现高效的数据监控与可视化。 ... [详细]
  • KMP算法是处理字符串匹配的一种高效算法它首先用O(m)的时间对模板进行预处理,然后用O(n)的时间完成匹配。从渐进的意义上说,这样时间复 ... [详细]
  • 本文探讨了在iOS平台上开发BLE(蓝牙低功耗)应用程序时遇到的挑战,特别是如何实现应用在后台模式下仍能持续扫描并连接蓝牙设备。文章提供了具体的配置方法和常见的问题解决方案。 ... [详细]
  • CSS高级技巧:动态高亮当前页面导航
    本文介绍了如何使用CSS实现网站导航栏中当前页面的高亮显示,提升用户体验。通过为每个页面的body元素添加特定ID,并结合导航项的类名,可以轻松实现这一功能。 ... [详细]
  • Linux环境下进程间通信:深入解析信号机制
    本文详细探讨了Linux系统中信号的生命周期,从信号生成到处理函数执行完毕的全过程,并介绍了信号编程中的注意事项和常见应用实例。通过分析信号在进程中的注册、注销及处理过程,帮助读者理解如何高效利用信号进行进程间通信。 ... [详细]
author-avatar
忽而今秋_丶
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有