热门标签 | 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))

推荐阅读
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 本文将介绍由密歇根大学Charles Severance教授主讲的顶级Python入门系列课程,该课程广受好评,被誉为Python学习的最佳选择。通过生动有趣的教学方式,帮助初学者轻松掌握编程基础。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 在金融和会计领域,准确无误地填写票据和结算凭证至关重要。这些文件不仅是支付结算和现金收付的重要依据,还直接关系到交易的安全性和准确性。本文介绍了一种使用C语言实现小写金额转换为大写金额的方法,确保数据的标准化和规范化。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • This document outlines the recommended naming conventions for HTML attributes in Fast Components, focusing on readability and consistency with existing standards. ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 主要用了2个类来实现的,话不多说,直接看运行结果,然后在奉上源代码1.Index.javaimportjava.awt.Color;im ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本文探讨了 C++ 中普通数组和标准库类型 vector 的初始化方法。普通数组具有固定长度,而 vector 是一种可扩展的容器,允许动态调整大小。文章详细介绍了不同初始化方式及其应用场景,并提供了代码示例以加深理解。 ... [详细]
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社区 版权所有