码迷,mamicode.com
首页 > 其他好文 > 详细

一个简单的转换字母大小写的方法

时间:2015-07-29 13:56:44      阅读:104      评论:0      收藏:0      [点我收藏+]

标签:

【这里我们将要介绍一个最简单也最快速的转换字母大小写的方法,提示:使用位技巧】

【以下代码用C语言编写】

在编程的时候我们经常遇到需要转换字母大小写的情况,有时候就是这个问题,有时候是为了解决其它问题。大家应该能想到一些方法。我将要介绍一种最优美的方法,也就是用比特技巧解决问题。

这个技巧非常简单,就是用大小写字母的ASCII值来转换他们(大小写字母ASCII值相差32)。将字母的ASCII值的第5位(或者第6位,取决于你怎么数)进行异或运算,看下面:

a = 01100001
A = 01000001

看到了吧,只有第5位发生了变化。

为什么会这样呢?也许是发明ASCII的人认为这是好主意。如果你把a~z的ASCII值写下来,你会发现,所有第5比特的值都是1。于是发明的人就想:那为什么不把A~Z的ASCII值的第5位都设为0呢?这样我们转换大小写就容易多了,于是就这样了吧。

a = 01100001    A = 01000001 
b = 01100010    B = 01000010 
c = 01100011    C = 01000011 
d = 01100100    D = 01000100 
e = 01100101    E = 01000101 
f = 01100110    F = 01000110 
g = 01100111    G = 01000111 
h = 01101000    H = 01001000 
i = 01101001    I = 01001001 
j = 01101010    J = 01001010 
k = 01101011    K = 01001011 
l = 01101100    L = 01001100 
m = 01101101    M = 01001101 
n = 01101110    N = 01001110 
o = 01101111    O = 01001111 
p = 01110000    P = 01010000 
q = 01110001    Q = 01010001 
r = 01110010    R = 01010010 
s = 01110011    S = 01010011 
t = 01110100    T = 01010100 
u = 01110101    U = 01010101 
v = 01110110    V = 01010110 
w = 01110111    W = 01010111 
x = 01111000    X = 01011000 
y = 01111001    Y = 01011001 
z = 01111010    Z = 01011010

现在看下面的代码,将我们要转换大小写的字母与空格进行异或(xor)运算:

#include<stdio.h>
int main(void)
{
    char x = A;
    char y = b;
 
    printf("Original case:- %c %c",x,y);
 
    x = x ^  ;
    y = y ^  ;
 
    printf("\n\nChanged case:- %c %c",x,y);
 
    return 0;
}

有人问:为什么是空格?因为空格的ASCII值是32,1左移5位,也就是第5比特。

原文来自http://www.studyalgorithms.com/string/easiest-way-to-change-case-of-alphabets/

一个简单的转换字母大小写的方法

标签:

原文地址:http://www.cnblogs.com/programnote/p/4685565.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!