Leetcode每日一练 5.21 (初学者勿喷)补

ps:在今天的题写之前有一个最大公约数,和最小公倍数的知识。

gcd函数利用递归就可以得到最大公约数。

对于lcm函数就是求最小公倍数。

只要用两个整数的乘积除两者的最大公约数。

正文:

首先查明字符串的长度,标记为数组。

然后挨个遍历,if判断ascii码如果真的是大写代码,那么就将ASCII码转化为小写的。

其中最重要的是

s[i] |= 32;

这一句符合条件的值会根据ASCII码的底层按照按位或逻辑会转化为小写的。

相关资料根据ai:

ASCII(American Standard Code for Information Interchange,美国信息交换标准代码)是一种基于拉丁字母的字符编码标准,主要用于显示现代英语和其他西欧语言。在ASCII编码中,大写字母和小写字母的编码值是连续的,并且有一定的间隔。

具体来说,大写字母A到Z的ASCII编码值从65(二进制 1000001)开始,依次递增;小写字母a到z的ASCII编码值从97(二进制 1100001)开始,也依次递增。请注意,这里二进制表示的前三位都是相同的(100或110),只是第四位不同。

当你将一个大写字母的ASCII编码值按位或加上32(二进制 00100000)时,实际上只改变了这个二进制数的第四位(根据二进制第四位改变为1之后正好是加了32)。由于大写字母的第四位是0,而小写字母的第四位是1,所以加上32(即将第四位从0变为1)后,该字符的ASCII编码值就变成了对应的小写字母的编码值。

举个例子,大写字母A的ASCII编码值是65(二进制 1000001),按位或加上32(二进制 00100000)后得到97(二进制 1100001),这恰好是小写字母a的ASCII编码值。

因此,在ASCII编码中,将大写字母的编码值按位或加上32就可以得到对应的小写字母的编码值。这种转换方法在计算机编程中经常用于大小写转换。

  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值