15天算法入门(四)

简介: 本文反转字符串和反转字符串中的单词III

网络异常,图片无法展示
|

网络异常,图片无法展示
|


反转字符串


题目


编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 char[] 的形式给出。


不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。


你可以假设数组中的所有字符都是 ASCII 码表中的可打印字符。

 

示例 1:
输入:["h","e","l","l","o"]
输出:["o","l","l","e","h"]


题解


思路一:

找到中间点,设定中间点的左右两边位置为左右指针,分别向两边扩散交换。

中间点需要根据数组长度的奇偶来判断。偶数,左右指针就指向长度一半的前一个位置和一半的位置;奇数,左右指针分别指向中间数的左右两边的位置。

网络异常,图片无法展示
|
思路二:

设定左右指针,分别指向头和尾。两个指针相向而行,互相交换,当左右指针相遇或左指针超过右指针时,跳出循环,返回数组。

网络异常,图片无法展示
|


代码


思路一:


var reverseString = function (s) {
    let l, r
    if (s.length % 2 === 0) {
        l = (s.length >> 1) - 1
        r = s.length >> 1
    } else {
        l = (s.length >> 1) - 1
        r = (s.length >> 1) + 1
    }
    while (l >= 0 && r < s.length) {
        swap(s, l--, r++)
    }
    return s
};
function swap(arr, i, j) {
    let temp = arr[i]
    arr[i] = arr[j]
    arr[j] = temp
}


思路二:


var reverseString = function (s) {
    let l = 0, r = s.length - 1
    while (l < r) {
        swap(s, l++, r--)
    }
    return s
};
function swap(arr, i, j) {
    let temp = arr[i]
    arr[i] = arr[j]
    arr[j] = temp
}
复制代码


反转字符串中的单词III


题目


给定一个字符串,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序。  


示例:
输入:"Let's take LeetCode contest"
输出:"s'teL ekat edoCteeL tsetnoc"


题解


这题主要考察字符串与数组之间切换,还有数组的反转。

先将字符串按空格分割成数组,然后在每个小段字符串中,将其变成数组反转,在拼成字符串。最后用空格将其再拼接成一个长的字符串。


代码


var reverseWords = function (s) {
    let arr = s.split(' ')
    let res = []
    for (let i = 0; i < arr.length; i++) {
        res.push(arr[i].split('').reverse().join(''))
    }
    return res.join(' ')
};


题目来源:leetcode

目录
相关文章
|
1月前
|
机器学习/深度学习 人工智能 算法
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
本文全面介绍了人工智能(AI)的基础知识、操作教程、算法实现及其在实际项目中的应用。首先,从AI的概念出发,解释了AI如何使机器具备学习、思考、决策和交流的能力,并列举了日常生活中的常见应用场景,如手机助手、推荐系统、自动驾驶等。接着,详细介绍了AI在提高效率、增强用户体验、促进技术创新和解决复杂问题等方面的显著作用,同时展望了AI的未来发展趋势,包括自我学习能力的提升、人机协作的增强、伦理法规的完善以及行业垂直化应用的拓展等...
148 3
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
|
2月前
|
机器学习/深度学习 数据采集 人工智能
机器学习算法入门与实践
【7月更文挑战第22天】机器学习算法入门与实践是一个既充满挑战又极具吸引力的过程。通过掌握基础知识、理解常见算法、注重数据预处理和模型选择、持续学习新技术和参与实践项目,你可以逐步提高自己的机器学习技能,并在实际应用中取得优异的成绩。记住,机器学习是一个不断迭代和改进的过程,保持好奇心和耐心,你将在这个领域走得更远。
|
2月前
|
消息中间件 存储 算法
实战算法的基础入门(2)
实战算法的基础入门
|
2月前
|
算法 大数据
实战算法的基础入门(1)
实战算法的基础入门
|
1月前
|
存储 算法
【C算法】编程初学者入门训练140道(1~20)
【C算法】编程初学者入门训练140道(1~20)
|
2月前
|
算法 Java
实战算法的基础入门(3)
实战算法的基础入门
|
3月前
|
算法 程序员
高阶算法班从入门到精通之路
高阶算法班从入门到精通之路
30 3
|
3月前
|
机器学习/深度学习 人工智能 自然语言处理
机器学习算法入门:从K-means到神经网络
【6月更文挑战第26天】机器学习入门:从K-means到神经网络。文章涵盖了K-means聚类、逻辑回归、决策树和神经网络的基础原理及应用场景。K-means用于数据分组,逻辑回归适用于二分类,决策树通过特征划分做决策,神经网络则在复杂任务如图像和语言处理中大显身手。是初学者的算法导览。
|
3月前
|
自然语言处理 算法
ransformers从入门到精通:常用的subword tokenizer算法
- WordPiece、BPE/BBPE最小字词进行合并最终字词,BPE/BBPE直接采用词频判断合并规则而WordPiece采用最大似然的方式 - unigram采用从最大的字词集合里移除那些对语料库整体概率贡献最小的子词【6月更文挑战第7天】
75 3
|
3月前
|
存储 自然语言处理 算法
位运算入门及简单算法题的应用
位运算入门及简单算法题的应用
26 1