返回介绍

solution / 0200-0299 / 0271.Encode and Decode Strings / README_EN

发布于 2024-06-17 01:04:02 字数 5903 浏览 0 评论 0 收藏 0

271. Encode and Decode Strings

中文文档

Description

Design an algorithm to encode a list of strings to a string. The encoded string is then sent over the network and is decoded back to the original list of strings.

Machine 1 (sender) has the function:

string encode(vector<string> strs) {
  // ... your code
  return encoded_string;
}

Machine 2 (receiver) has the function:

vector<string> decode(string s) {
  //... your code
  return strs;
}

So Machine 1 does:

string encoded_string = encode(strs);

and Machine 2 does:

vector<string> strs2 = decode(encoded_string);

strs2 in Machine 2 should be the same as strs in Machine 1.

Implement the encode and decode methods.

You are not allowed to solve the problem using any serialize methods (such as eval).

 

Example 1:

Input: dummy_input = ["Hello","World"]
Output: ["Hello","World"]
Explanation:
Machine 1:
Codec encoder = new Codec();
String msg = encoder.encode(strs);
Machine 1 ---msg---> Machine 2

Machine 2:
Codec decoder = new Codec();
String[] strs = decoder.decode(msg);

Example 2:

Input: dummy_input = [""]
Output: [""]

 

Constraints:

  • 1 <= strs.length <= 200
  • 0 <= strs[i].length <= 200
  • strs[i] contains any possible characters out of 256 valid ASCII characters.

 

Follow up: Could you write a generalized algorithm to work on any possible set of characters?

Solutions

Solution 1

class Codec:
  def encode(self, strs: List[str]) -> str:
    """Encodes a list of strings to a single string."""
    return chr(257).join(strs)

  def decode(self, s: str) -> List[str]:
    """Decodes a single string to a list of strings."""
    return s.split(chr(257))


# Your Codec object will be instantiated and called as such:
# codec = Codec()
# codec.decode(codec.encode(strs))
public class Codec {

  // Encodes a list of strings to a single string.
  public String encode(List<String> strs) {
    StringBuilder ans = new StringBuilder();
    for (String s : strs) {
      ans.append((char) s.length()).append(s);
    }
    return ans.toString();
  }

  // Decodes a single string to a list of strings.
  public List<String> decode(String s) {
    List<String> ans = new ArrayList<>();
    int i = 0, n = s.length();
    while (i < n) {
      int size = s.charAt(i++);
      ans.add(s.substring(i, i + size));
      i += size;
    }
    return ans;
  }
}

// Your Codec object will be instantiated and called as such:
// Codec codec = new Codec();
// codec.decode(codec.encode(strs));
class Codec {
public:
  // Encodes a list of strings to a single string.
  string encode(vector<string>& strs) {
    string ans;
    for (string s : strs) {
      int size = s.size();
      ans += string((const char*) &size, sizeof(size));
      ans += s;
    }
    return ans;
  }

  // Decodes a single string to a list of strings.
  vector<string> decode(string s) {
    vector<string> ans;
    int i = 0, n = s.size();
    int size = 0;
    while (i < n) {
      memcpy(&size, s.data() + i, sizeof(size));
      i += sizeof(size);
      ans.push_back(s.substr(i, size));
      i += size;
    }
    return ans;
  }
};

// Your Codec object will be instantiated and called as such:
// Codec codec;
// codec.decode(codec.encode(strs));
type Codec struct {
}

// Encodes a list of strings to a single string.
func (codec *Codec) Encode(strs []string) string {
  ans := &bytes.Buffer{}
  for _, s := range strs {
    t := fmt.Sprintf("%04d", len(s))
    ans.WriteString(t)
    ans.WriteString(s)
  }
  return ans.String()
}

// Decodes a single string to a list of strings.
func (codec *Codec) Decode(strs string) []string {
  ans := []string{}
  i, n := 0, len(strs)
  for i < n {
    t := strs[i : i+4]
    i += 4
    size, _ := strconv.Atoi(t)
    ans = append(ans, strs[i:i+size])
    i += size
  }
  return ans
}

// Your Codec object will be instantiated and called as such:
// var codec Codec
// codec.Decode(codec.Encode(strs));

Solution 2

class Codec:
  def encode(self, strs: List[str]) -> str:
    """Encodes a list of strings to a single string."""
    ans = []
    for s in strs:
      ans.append('{:4}'.format(len(s)) + s)
    return ''.join(ans)

  def decode(self, s: str) -> List[str]:
    """Decodes a single string to a list of strings."""
    ans = []
    i, n = 0, len(s)
    while i < n:
      size = int(s[i : i + 4])
      i += 4
      ans.append(s[i : i + size])
      i += size
    return ans


# Your Codec object will be instantiated and called as such:
# codec = Codec()
# codec.decode(codec.encode(strs))

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文