C/C++ 获取汉字拼音首字母
#include <stdint.h>
#include <stdio.h>
#include <ctype.h>
#include <string.h> bool between(uint32_t start,uint32_t end,uint32_t aim);
char get_first_letter(wchar_t wchar);
void get_first_letters(const char *szChinese,char piyinBuf[],const uint32_t maxBufLen,uint32_t &piyinBufLen); int32_t main()
{
char buf[] = {};
uint32_t len = ;
const char *szChinese = "qaz123获取汉字拼音";
get_first_letters(szChinese,buf,,len);
printf("%s\n",buf);
return ;
} void get_first_letters(const char *szChinese,char piyinBuf[],const uint32_t maxBufLen,uint32_t &piyinBufLen)
{
uint8_t chr[];
piyinBufLen = ;
uint32_t chineseLen = strlen(szChinese);
for (uint32_t i = ; i < chineseLen && piyinBufLen < maxBufLen; ++i)
{
uint8_t c = szChinese[i];
// 排除askii 码
if (isascii(c))
{
piyinBuf[piyinBufLen++] = c;
}
else
{
chr[] = szChinese[i];
chr[] = szChinese[++i];
chr[] = ;
wchar_t wchr = ;
wchr = (chr[] & 0xff) << ;
wchr |= (chr[] & 0xff);
piyinBuf[piyinBufLen++] = toupper(get_first_letter(wchr));
}
}
} bool between(wchar_t start,wchar_t end,wchar_t aim)
{
if (start <= aim && aim <= end)
{
return true;
}
return false;
} char get_first_letter(wchar_t wchar)
{
if (between(0xB0A1,0xB0C4,wchar)) return 'a';
if (between(0XB0C5,0XB2C0,wchar)) return 'b';
if (between(0xB2C1,0xB4ED,wchar)) return 'c';
if (between(0xB4EE,0xB6E9,wchar)) return 'd';
if (between(0xB6EA,0xB7A1,wchar)) return 'e';
if (between(0xB7A2,0xB8c0,wchar)) return 'f';
if (between(0xB8C1,0xB9FD,wchar)) return 'g';
if (between(0xB9FE,0xBBF6,wchar)) return 'h';
if (between(0xBBF7,0xBFA5,wchar)) return 'j';
if (between(0xBFA6,0xC0AB,wchar)) return 'k';
if (between(0xC0AC,0xC2E7,wchar)) return 'l';
if (between(0xC2E8,0xC4C2,wchar)) return 'm';
if (between(0xC4C3,0xC5B5,wchar)) return 'n';
if (between(0xC5B6,0xC5BD,wchar)) return 'o';
if (between(0xC5BE,0xC6D9,wchar)) return 'p';
if (between(0xC6DA,0xC8BA,wchar)) return 'q';
if (between(0xC8BB,0xC8F5,wchar)) return 'r';
if (between(0xC8F6,0xCBF0,wchar)) return 's';
if (between(0xCBFA,0xCDD9,wchar)) return 't';
if (between(0xCDDA,0xCEF3,wchar)) return 'w';
if (between(0xCEF4,0xD188,wchar)) return 'x';
if (between(0xD1B9,0xD4D0,wchar)) return 'y';
if (between(0xD4D1,0xD7F9,wchar)) return 'z';
return '\0';
}
C/C++ 获取汉字拼音首字母的更多相关文章
- C# 获取汉字拼音首字母
最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来. 十年河东十年河西,莫欺少年穷 学无止境,精益求精 本节探讨C#获取汉字拼音首字母的方法: 代码类东西, ...
- C# 获取汉字拼音首字母/全拼
最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来. 十年河东十年河西,莫欺少年穷 学无止境,精益求精 本节探讨C#获取汉字拼音首字母的方法: 代码类东西, ...
- java获取汉字拼音首字母 --转载
在项目中要更能根据某些查询条件(比如姓名)的首字母作为条件进行查询,比如查一个叫"李晓明"的人,可以输入'lxm'.写了一个工具类如下: import java.io.Unsupp ...
- JAVA获取汉字拼音首字母
package com.common.util; import java.io.UnsupportedEncodingException; /** * 取得给定汉字串的首字母串,即声母串 * Titl ...
- php获取汉字拼音首字母的方法
现实中我们经常看到这样的说明,排名不分先后,按姓名首字母进行排序.这是中国人大多数使用的排序方法.那么在php程序中该如何操作呢? 下面就分享一下在php程序中获取汉字拼音的首字母的方法,在网上搜到的 ...
- qt 获取汉字拼音首字母
#include "mainwindow.h"#include "ui_mainwindow.h"#include <QDebug>#include ...
- php 获取汉字拼音首字母的函数
function getFirstChar($string){ if($string{0}>="A" and $string{0}<="z" )re ...
- 获取汉字拼音&首字母
pinyin4j https://www.cnblogs.com/yjq520/p/7681537.html
- PHP获取汉字拼音首字母 截取中文字符串
http://blog.csdn.net/everything1209/article/details/39005785 substr是按字符分割,而mb_strcut是按字节来分割,但是都不会产生半 ...
随机推荐
- Playmaker Input篇教程之Playmaker购买下载和导入
Playmaker Input篇教程之Playmaker购买下载和导入 Playmaker Input篇认识Playmaker Playmaker是Unity的插件,其标志如图1-1所示.开发者使用它 ...
- 游戏控制杆OUYA游戏开发快速入门教程
游戏控制杆OUYA游戏开发快速入门教程 1.2.2 游戏控制杆 游戏控制杆各个角度的视图,如图1-4所示,它的硬件规格是本文选自OUYA游戏开发快速入门教程大学霸: 图1-4 游戏控制杆各个角度的 ...
- eBay 消息发送(1)
1.简介 Call Index Doc: http://developer.ebay.com/DevZone/XML/docs/Reference/eBay/index.html 消息发送主要 ...
- BZOJ3836 : [Poi2014]Tourism
对于一个连通块,取一个点进行dfs,得到一棵dfs搜索树,则这棵树的深度不超过10,且所有额外边都是前向边. 对于每个点x,设S为三进制状态,S第i位表示根到x路径上深度为i的点的状态: 0:选了 1 ...
- BZOJ3827 : [Poi2014]Around the world
把环倍长,破环成链 设f[i]表示i一次性能飞达的最右边的点,因为f[]单调递增,所以可以$O(n)$求出 这样就形成了一个树结构,对于每个节点,在其到根节点路径上二分出深度最大的点,使得其飞过一圈 ...
- BZOJ3829 : [Poi2014]FarmCraft
d[x]表示走完x的子树并回到x所需的时间 f[x]表示从走到x开始计时,x子树中最晚的点安装完的最早时间 d[x]=sum(d[i]+2),i是x的孩子 f[x]的计算比较复杂: 考虑将x的各棵子树 ...
- Java学习第一步: Win7配置JDK环境
转摘"专注JavaWeb开发":http://www.javaweb1024.com/java/Javajichu/2015/03/02/353.html 下载JDK并安装到本机 ...
- java如何产生随机数
一.java如何产生随机数? 1.打开eclipse 2.新建java项目,例如取名为“suijishu”点击完成 3.新建一个类进行测试 4.首先要在头部插入一个包 输入import java.ut ...
- 分布式架构高可用架构篇_03-redis3集群的安装高可用测试
参考文档 Redis 官方集群指南:http://redis.io/topics/cluster-tutorial Redis 官方集群规范:http://redis.io/topics/cluste ...
- HDU 2594 Simpsons’ Hidden Talents(KMP的Next数组应用)
Simpsons’ Hidden Talents Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java ...