news 2026/3/27 22:52:13

(100分)- 单词倒序(Java JS Python)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(100分)- 单词倒序(Java JS Python)

(100分)- 单词倒序(Java & JS & Python)

题目描述

输入单行英文句子,里面包含英文字母,空格以及,.?三种标点符号,请将句子内每个单词进行倒序,并输出倒序后的语句。

输入描述

输入字符串S,S的长度 1 ≤ N ≤ 100

输出描述

输出倒序后的字符串

备注

标点符号左右的空格 ≥ 0,单词间空格>0

用例
输入yM eman si boB.
输出My name is Bob.
说明
输入woh era uoy ? I ma enif.
输出how are you ? I am fine.
说明
题目解析

从用例可以看出,单词的倒序并不难,将字符串单词转为字符数组后,reverse一下就行了。但是单词中如果有标点符号的话,则标点符号的位置不能改变,比如enif. 倒序后为 fine. 其中 . 的位置在倒序前后是一样的。

我的解题思路如下,从左到右遍历每一个字符,如果字符是 , . ? 或者空格,则看成一个分界符,将分界符之间的单词片段进行倒序。

JavaScript算法源码
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); rl.on("line", (line) => { console.log(getResult(line)); }); function getResult(str) { const reg = /[\,\.\?\s]/; const idxs = [-1]; for (let i = 0; i < str.length; i++) { if (reg.test(str[i])) { idxs.push(i); } } idxs.push(str.length); const arr = [...str]; idxs.reduce((p, c) => { let l = p + 1; let r = c - 1; while (l < r) { let tmp = arr[l]; arr[l] = arr[r]; arr[r] = tmp; l++; r--; } return c; }); return arr.join(""); }

更精简的解法,可以利用String.prototype.repalce的正则匹配出输入字符串中各个英文子串,将这些英文子串替换为倒序子串

/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); rl.on("line", (line) => { console.log(getResult(line)); }); function getResult(str) { return str.replace(/[a-zA-Z]+/g, (s) => [...s].reverse().join("")); }
Java算法源码
import java.util.ArrayList; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String str = sc.nextLine(); System.out.println(getResult(str)); } public static String getResult(String str) { ArrayList<Integer> idxs = new ArrayList<>(); idxs.add(-1); for (int i = 0; i < str.length(); i++) { if (",.? ".indexOf(str.charAt(i)) != -1) { idxs.add(i); } } idxs.add(str.length()); char[] chars = str.toCharArray(); for (int i = 0; i < idxs.size() - 1; i++) { int l = idxs.get(i) + 1; int r = idxs.get(i + 1) - 1; while (l < r) { char tmp = chars[l]; chars[l] = chars[r]; chars[r] = tmp; l++; r--; } } StringBuilder sb = new StringBuilder(); for (char c : chars) { sb.append(c); } return sb.toString(); } }
Python算法源码
import re s = input() p = re.compile(r"[\\,\\.\\?\s]") idxs = [-1] for i in range(len(s)): if p.match(s[i]): idxs.append(i) idxs.append(len(s)) arr = [c for c in s] for i in range(len(idxs) - 1): l = idxs[i] + 1 r = idxs[i + 1] - 1 while l < r: arr[l], arr[r] = arr[r], arr[l] l += 1 r -= 1 print("".join(arr))

更精简的,可以利用re.sub(pattern, repl, string, count=0, flags=0)

其中repl可以是一个函数,该函数接收被pattern正则匹配结果re.Match类型的值作为入参matched,我们可以通过matched.group()获取出匹配的子串,并对它做反转处理,然后返回给re.sub进行替换

import re s = input() def rep(matched): tmp = list(matched.group()) tmp.reverse() return "".join(tmp) print(re.sub(r"[a-zA-Z]+", rep, s))
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/24 15:11:50

【课程设计/毕业设计】基于SpringBoot校园生活服务小程序基于springboot+小程序的高校生活互助平台小程序【附源码、数据库、万字文档】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/3/15 18:47:36

leetcode 923. 3Sum With Multiplicity 三数之和的多种可能

Problem: 923. 3Sum With Multiplicity 三数之和的多种可能 排序&#xff0c;哈希表记录每个数字的频次&#xff0c;双循环&#xff0c;拿到两个数字&#xff0c;最后一个数字相减得到&#xff0c;然后通过排列组合计算答案&#xff0c;需要考虑是否存在这样的情况&#xff0c;…

作者头像 李华
网站建设 2026/3/26 9:47:34

《Java并发编程的艺术》| 并发关键字与 JMM 核心规则

摘要&#xff1a;本篇文章围绕 Java 并发编程核心&#xff0c;梳理了 volatile、synchronized的实现原理与特性 &#xff1b;同时详解了 JMM&#xff0c;需配合 volatile、synchronized等工具&#xff0c;才能实现多线程下共享变量的原子性、可见性和有序性保障。 第2章 Java并…

作者头像 李华
网站建设 2026/3/26 19:03:02

93基于三菱PLC和组态王的兰花灌溉控制系统的农业农田应用

93基于三菱PLC和组态王的兰花灌溉控制系统的农业农田 兰花这种傲娇的植物&#xff0c;浇多了烂根&#xff0c;浇少了干枯&#xff0c;传统人工浇水能把种植户逼疯。去年在云南花卉基地看到师傅们凌晨三点打着手电筒浇水&#xff0c;我就琢磨着用三菱FX3U PLC搭个自动灌溉系统&…

作者头像 李华
网站建设 2026/3/15 18:47:38

专升本高数资源合集

2022专升本数学全程班&#xff08;完结&#xff09; 文件大小: 45.4GB内容特色: 2022专升本数学全程录播&#xff0c;45GB高清适用人群: 专科升本人群、数学基础薄弱需系统复习者核心价值: 考点全覆盖真题精讲&#xff0c;一站式冲刺高分下载链接: https://pan.quark.cn/s/05f…

作者头像 李华