面试算法题

本文记录了在两家公司面试中遇到的有趣算法问题,主要涉及字符串的压缩与解压。在字符串压缩题目中,讨论了如何处理字符计数不超过9的情况及其扩展;而在字符串解压部分,则探讨了解码压缩后的字符串的方法。
摘要由CSDN通过智能技术生成

参加了两家小小小公司的面试,有几道比较有趣记录了下来

1.字符串压缩

不考虑字符数超过9。

#include <string>
#include <iostream>

std::string solution(std::string s) {
  std::string ans;
  int i = 0, j = 0;
  while (i < int(s.length())) {
    while (s[i] == s[j]) ++i;
    ans += s[j];
    ans += std::to_string(i - j);
    j = i;
  }
  return ans;
}
int main() {
  // 输入
  std::string s;
  std::cin >> s;
  // 字符串压缩
  std::string ans = solution(s);
  // 输出
  std::cout << ans;
}

考虑字符数超过9。

#include <string>
#include <iostream>

std::string solution(std::string s) {
  std::string ans;
  int i = 0, j = 0;
  w
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值