得到汉字的首拼

#include <iostream> #include <string> using namespace std; static char convert(wchar_t n); static bool In(wchar_t start, wchar_t end, wchar_t code); int main(int argc, char* argv[]) { string sChinese = "我爱中国"; // 输入的字符串 char chr[3]; wchar_t wchr = 0; char* buff = new char[sChinese.length()/2]; memset(buff, 0x00, sizeof(char)*sChinese.length()/2+1); for (int i = 0, j = 0; i < (sChinese.length()/2); ++i) { memset(chr, 0x00, sizeof(chr)); chr[0] = sChinese[j++]; chr[1] = sChinese[j++]; chr[2] = '/0'; // 单个字符的编码 如:'我' = 0xced2 wchr = 0; wchr = (chr[0] & 0xff) << 8; wchr |= (chr[1] & 0xff); buff[i] = convert(wchr); } cout << "pin yin = [" << buff << "]" << endl; return 0; } char convert(wchar_t n) { if (In(0xB0A1,0xB0C4,n)) return 'a'; if (In(0XB0C5,0XB2C0,n)) return 'b'; if (In(0xB2C1,0xB4ED,n)) return 'c'; if (In(0xB4EE,0xB6E9,n)) return 'd'; if (In(0xB6EA,0xB7A1,n)) return 'e'; if (In(0xB7A2,0xB8c0,n)) return 'f'; if (In(0xB8C1,0xB9FD,n)) return 'g'; if (In(0xB9FE,0xBBF6,n)) return 'h'; if (In(0xBBF7,0xBFA5,n)) return 'j'; if (In(0xBFA6,0xC0AB,n)) return 'k'; if (In(0xC0AC,0xC2E7,n)) return 'l'; if (In(0xC2E8,0xC4C2,n)) return 'm'; if (In(0xC4C3,0xC5B5,n)) return 'n'; if (In(0xC5B6,0xC5BD,n)) return 'o'; if (In(0xC5BE,0xC6D9,n)) return 'p'; if (In(0xC6DA,0xC8BA,n)) return 'q'; if (In(0xC8BB,0xC8F5,n)) return 'r'; if (In(0xC8F6,0xCBF0,n)) return 's'; if (In(0xCBFA,0xCDD9,n)) return 't'; if (In(0xCDDA,0xCEF3,n)) return 'w'; if (In(0xCEF4,0xD188,n)) return 'x'; if (In(0xD1B9,0xD4D0,n)) return 'y'; if (In(0xD4D1,0xD7F9,n)) return 'z'; return '/0'; } bool In(wchar_t start, wchar_t end, wchar_t code) { if (code >= start && code <= end) { return true; } return false; }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MFC是Microsoft Foundation Class库的简称,它是用于开发Windows桌面应用程序的一个C++类库。在MFC中提取汉字字母可以通过以下步骤实现: 1. 将汉字字符串转换为Unicode编码:先将字符串转换为宽字符型CString类型对象,然后使用WideCharToMultiByte函数将其转换为Unicode编码。 2. 提取汉字字母:遍历汉字字符串的每个字符,对于每个汉字字符,判断其Unicode编码是否在汉字范围内(0x4E00-0x9FA5)。 3. 对于汉字字符,利用其Unicode编码计算出字母的索引:先减去0x4E00(或转换为十进制得19968),然后除以94将其余数与0x41(十进制为65)相加。 4. 将字母索引转换为对应的字符:加上0x41得到的索引即为字母的ASCII码,使用对应的ASCII码转换为字符,即可得到字母。 5. 将提取的字母存储起来:可以使用一个字符型变量或字符串对象,依次将每个汉字字母接起来。 需要注意的是,在提取汉字字母时,还需要考虑到多音字的情况,因为一个汉字可能对应多个不同的音节。一种常用的方法是使用音库,将汉字转换为音,然后提取音的字母作为汉字字母。 以上是一种基于汉字Unicode编码的提取字母的方法,在实际应用中,还可以使用其他的提取规则,如使用音库或其他语言处理库来实现。总之,根据具体需求选择合适的方法,可以实现汉字字母的提取。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值