go 语言圣经练习解答 -- 第四章 (关闭)
go语言圣经(The Go Programming Language)第四章练习题答案
练习 4.1: 编写一个函数,计算两个SHA256哈希码中不同bit的数目。(参考2.6.2节的 PopCount函数。)
解题思路
- 循环字节数组
- 循环字节bit,对比是否相同
练习 4.2: 编写一个程序,默认打印标准输入的以SHA256哈希码,也可以通过命令行标准参 数选择SHA384或SHA512哈希算法。
解题思路
- 获取命令行输入的参数
- 通过命令行参数返回值
练习 4.3: 重写reverse函数,使用数组指针代替slice。
解题思路(无)
练习 4.4: 编写一个rotate函数,通过一次循环完成旋转。
解题思路
- 从新创建一个数组,新数组下标为原数组下标加上偏移值
- 如果超出最大长度则从最左边开始
练习 4.6: 写一个函数在原地完成消除[]string中相邻重复的字符串的操作。
解题思路
- 原地完成消除 / 相邻重复
- 原地消除表示必须在原有的数组上操作
- 遇到相同的先前移一位
- 下标保持不动继续检测当前位置是否跟下一位重复
练习 4.6: 编写一个函数,原地将一个UTF-8编码的[]byte类型的slice中相邻的空格(参考
unicode.IsSpace)替换成一个空格返回
解题思路
- 基本一4.5一致,只是判断字母变成了判断空格
练习 4.7: 修改reverse函数用于原地反转UTF-8编码的[]byte。是否可以不用分配额外的内
存?
解题思路
- 与原本的reverse基本一致
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 顾澜的技术小站!
评论
GitalkValine