如何判断全角半角

int IsChineseOrEnglish(LPCSTR pText)
{
 unsigned char sqChar[10];
 sqChar[0]=*pText;
 sqChar[1]='/0';
 if (sqChar[0]>=0xa1)
 {
  if (sqChar[0]==0xa3)
  {
   return 1;//全角字符  }
  else
  {
   return 2;//汉字  }
 }
 else
 {
  return 0;//英文,英文标点,数字

 }
}
bool GetNumChineseAndNumEnglish(const char*pSrc, int &nNumChiRet, int &nNumEngRet)//获得汉字与英文的个数
{
 if (pSrc == NULL)
 {
  return false;
 }
 else
 {
  int nLen = strlen(pSrc);
  char *pTxt = new char[nLen +1];
  char *pHeader = pTxt;
  //LPCSTR pTxt = pSrc;
  strcpy(pTxt, pSrc);
  pTxt[nLen] = '/0';
  while (*pTxt != '/0')
  {
   int nRet = IsChineseOrEnglish(pTxt);
   switch (nRet)
   {
   case 0:
    ++ nNumEngRet;
    pTxt++;
    break;
   case 1:
   case 2:
    ++ nNumChiRet;
    pTxt++;
    pTxt++;
    break;
   default:
    break;
   }
   
  }
  if (pHeader != NULL)
  {
   delete [] pHeader;
   pHeader = NULL;
  }
  return true;
 }
}

下面是完整的测试程序:

#include <windows.h>  
#include <iostream>
using namespace std;
int IsChineseOrEnglish(LPCSTR pText);
bool GetNumChineseAndNumEnglish(const char*pSrc, int &nNumChiRet, int &nNumEngRet);ÎĵÄ×Ö·û¸öÊý
int main(int argc,char**argv)  
{  

 int nNumChin = 0;
 int nNumEng = 0;
 GetNumChineseAndNumEnglish("£áÑîСӱYanger7", nNumChin, nNumEng);
 cout << "Number of Chinese:" << nNumChin << endl;
 cout << "Number of English:" << nNumEng << endl;
 return 0;  
}  


int IsChineseOrEnglish(LPCSTR pText)
{
 unsigned char sqChar[10];
 sqChar[0]=*pText;
 sqChar[1]='/0';
 if (sqChar[0]>=0xa1)
 {
  if (sqChar[0]==0xa3)
  {
   return 1;  }
  else
  {
   return 2;//ºº×Ö
  }
 }
 else
 {
  return 0; }
}
bool GetNumChineseAndNumEnglish(const char*pSrc, int &nNumChiRet, int &nNumEngRet){
 if (pSrc == NULL)
 {
  return false;
 }
 else
 {
  int nLen = strlen(pSrc);
  char *pTxt = new char[nLen +1];
  char *pHeader = pTxt;
  //LPCSTR pTxt = pSrc;
  strcpy(pTxt, pSrc);
  pTxt[nLen] = '/0';
  while (*pTxt != '/0')
  {
   int nRet = IsChineseOrEnglish(pTxt);
   switch (nRet)
   {
   case 0:
    ++ nNumEngRet;
    pTxt++;
    break;
   case 1:
   case 2:
    ++ nNumChiRet;
    pTxt++;
    pTxt++;
    break;
   default:
    break;
   }
   
  }
  if (pHeader != NULL)
  {
   delete [] pHeader;
   pHeader = NULL;
  }
  return true;
 }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值