进击吧!Pythonista(6/100)

简介: 进击吧!Pythonista(6/100)

压缩字符串

实现一个算法来压缩一个字符串。压缩的要求如下:

  • 需要判断压缩能不能节省空间,仅在压缩后字符串比原字符串长度更短时进行压缩。
  • 压缩的格式是将连续相同字符替换为字符+数字形式,例如 "AAABCCDDDD" 变为 "A3BC2D4"
  • 判断传入的字符串是否需要进行压缩,如果不需要压缩,返回原字符串;
  • 如果需要压缩,返回压缩后的字符串;
  • 如果传入的字符串是 None 或者空字符串,返回 None 或者空字符串。
class CompressString(object):
    def __init__(self, str1):
        self.str1 = str1
    def compress(self):
        if self.str1 is None or not self.str1:
            return self.str1
        result = ''
        prev_char = self.str1[0]
        count = 0
        for char in self.str1:
            if char == prev_char:
                count += 1
            else:
                result += self._calc_partial_result(prev_char, count)
                prev_char = char
                count = 1
        result += self._calc_partial_result(prev_char, count)
        return result if len(result) < len(self.str1) else self.str1
    def _calc_partial_result(self, prev_char, count):
        return prev_char + (str(count) if count > 1 else '')
if __name__ == '__main__':
    aaa = CompressString("AAABCCDDDD")
    print(aaa.compress())

反转字符串中的字符

实现一个算法来实现反转字符数组的功能。反转的要求如下:

  • 将字符数组的字符进行反转,例如 ['b', ' ', 'a', 'r'] 变成 ['r', 'a', ' ', 'b']
  • 将字符数组替换为反转后的数组。
  • 对于传入的字符数组,将字符数组的字符进行反转和替换,并返回替换后的字符数组;
  • 如果传入的字符数组是 None 或者空字符数组,返回 None 或者空字符数组。
class ReverseString(object):
    def __init__(self, chars):
        self.chars = chars
    def reverse(self):
        if self.chars:
            size = len(self.chars)
            for i in range(size // 2):
                self.chars[i], self.chars[size - 1 - i] = \
                    self.chars[size - 1 - i], self.chars[i]
        return self.chars
if __name__ == '__main__':
    aaa = ReverseString(['b', ' ', 'a', 'r'])
    print(aaa.reverse())

查找两个总和为特定值的索引

给定一个数组,找到两个总和为特定值的索引。

  • 例如给定数组 [1, 2, 3, -2, 5, 7],给定总和 7,则返回索引 [1, 4]
  • two_sum 函数接受两个参数,nums 用于指定传入的数组,val 用于指定和的值;
  • two_sum 函数输出含两个索引的数组,或者 TypeErrorValueError
  • 对于传入的数组 nums,返回总和为 val 的两个值的索引;
  • 如果数组中没有和为目标值的元素,则返回 None
  • 如果传入的数组 nums 或者目标值 valNone,需要使用 raise 语句显示 TypeError
  • 如果传入的数组为空数组,需要使用 raise 语句显示 ValueError
class Solution(object):
    def __init__(self, nums, val):
        self.nums = nums
        self.val = val
    def two_sum(self):
        if self.nums is None or self.val is None:
            raise TypeError('nums or target cannot be None')
        if not self.nums:
            raise ValueError('nums cannot be empty')
        cache = {}
        for index, num in enumerate(self.nums):
            cache_val = self.val - num
            if num in cache:
                return [cache[num], index]
            else:
                cache[cache_val] = index
        return None
if __name__ == '__main__':
    aaa = Solution([1, 2, 3, -2, 5, 7], 7)
    print(aaa.two_sum())

记得先自己做一遍再看答案哦~

Love&Share

[ 完 ]

相关文章
|
算法 Python
进击吧!Pythonista(3/100)
进击吧!Pythonista(3/100)
|
存储 算法
进击吧!Pythonista(9/100)
进击吧!Pythonista(9/100)
|
存储 弹性计算 运维
Serverless 奇点已来,下一个十年将驶向何方?
基于阿里云全面 Serverless 化的经历,阿里巴巴研究员、阿里云智能云原生应用平台总经理丁宇(叔同)阐述了企业应用架构的演进历程,以及 Serverless 兴起带来的行业变化。
125 0
Serverless 奇点已来,下一个十年将驶向何方?
|
架构师 Java 程序员
【毕业季|进击的技术er】作为一个职场人,我想对你们说
毕业季,是对青春的美好向往,经历了大学生涯之后,放下厚厚的书本,摒弃一道道繁杂的习题,在湛蓝的天空下、幽静的小树林里、迷人的海滩等山水美景间尽享自然的乐趣,是对大学生活最好的慰藉,也是对未来的职场生活最最大的尊重! 毕业了,离别宴,分手饭,兄弟情,姐妹情,爱情等各种感情开始接受考验了,对于风华正茂的青春,感情在这一时间是最好的黄金佳期,是对青春最好的告白!...
130 0
【毕业季|进击的技术er】作为一个职场人,我想对你们说
|
边缘计算 运维 Kubernetes
OpenYurt 邀你共赴 2022 EdgeX 中国挑战赛!
2022 年 8 月 3 日,由 LF Edge 主办的第三届 EdgeX 中国挑战赛正式开幕,阿里云作为本届大赛战略合作伙伴重磅亮相,希望通过其主导开源的云原生边缘计算智能平台 OpenYurt 与 EdgeX Foundry 的持续深入合作,共同为广大开发者构建一个物联网及边缘计算的学习和分享平台,以开源、共享的技术环境解决行业技术问题,促进云原生边缘计算、AIoT 等的应用落地及部署。
OpenYurt 邀你共赴 2022 EdgeX 中国挑战赛!
|
存储 弹性计算 运维
云上的潮玩社区,如何让年轻人念念不忘?
许多潮玩品牌正是看中千岛品牌资源整合的能力,首选在千岛微信小程序上进行新品首发、新品市场测试等业务。由于这些业务流量的激增,在业务架构上,如何有效应对突发流量、保障业务系统稳定性成了至关重要的问题。
1091 0
云上的潮玩社区,如何让年轻人念念不忘?
|
存储 缓存 前端开发
SegmentFault D-Day 南京站圆桌:技术与产品的结合
我们在今年的 SegmentFault D-Day 技术沙龙里加入了别具一格的「圆桌讨论」环节,圆桌偏重的是技术热点、成长历程以及创业路上的经验交流,和主体的严肃议题分享形成互补,就是为了做出更加 SegmentFault 式的沙龙体验,让技术与实际经验结合,让普通开发者与大牛更深入地交流。
194 0
SegmentFault D-Day 南京站圆桌:技术与产品的结合
|
机器学习/深度学习 存储 安全
聚焦区块链应用,SegmentFault 黑客马拉松引爆珠三角
聚焦区块链应用,SegmentFault 黑客马拉松引爆珠三角
332 0
聚焦区块链应用,SegmentFault 黑客马拉松引爆珠三角
|
前端开发 JavaScript 程序员
SegmentFault独家专访fengche.co:小而美的团队协作工具
fengche.co是一个刚刚好的中小团队协作工具。原名pragmatic.ly,2013年以来主攻国内市场,使用了更好记的新域。经过多次迭代的fengche.co,始终保持了简洁的风格。
423 0
SegmentFault独家专访fengche.co:小而美的团队协作工具
|
算法 搜索推荐 云计算
SegmentFault 成功入选微软创投加速器第四期,及背后的故事
接到微软创投加速器项目负责Vivian 最终决选的面试通过电话的时候,我那个时候正在从北京回杭州的高铁上面,我刚刚查了一下通话记录是在12月25日的下午4点钟左右 :) 那个时候刚刚结束了在北京两周的出差,每次去帝都出差都是工作狂模式,所以当时处于极度的疲惫状态,当时接到这个电话通知的时候还是小兴奋了一下,代表我们成功的从全国400多家企业的竞争中突破重围,成功入选微软创投云加速器的第四期了!
186 0
SegmentFault 成功入选微软创投加速器第四期,及背后的故事

热门文章

最新文章