c++字符串读取汉字

有个一个c++字符串s,里面有汉字也有字母,先区分出汉字与字母,再把汉字逐个读取出来;不用代码也可以,告诉我怎么做的方法。

第1个回答  推荐于2016-06-07
这个问题太有建设性意义了,我决定去尝试一下

#include<iostream>
#include<fstream>
#include<cstring>
using namespace std;

void main()
{
ifstream infile("file.txt");
if(!infile)
cerr<<"fail to open the file"<<endl;
int num=0,total=0;
char a;
while(infile.get(a))
{
if(a>=0)
num++;
total++;
}
cout<<total<<'\t'<<num<<endl;
infile.close();
infile.open("file.txt",ifstream::in);
char *character=new char[total-num+1];
int i=0;
while(infile.get(a))
{
if(int(a)<0)
{
character[i]=a;
infile.get(a);
character[i+1]=a;
i+=2;
}
}

character[total-num]='\0';

cout<<"the character in the string is"<<character<<endl;

infile.close();
}
已经多次检验,都正确,思路是汉字第一个字节的ASCII值小于零,而且汉字占用两个字节本回答被提问者采纳
第2个回答  2011-07-05
//C好像不太好弄
//C++没问题
#include<iostream>
#include<fstream>
int main(){
ifstream fin("a.txt");
string s;
while(fin>>s){
cout<<s<<endl;
}
}
//把你准备好的文字放在a.txt里和编译的文件放在同一个目录下
另外,虚机团上产品团购,超级便宜
第3个回答  2011-07-04
先用MultiByteToWideChar把UTF-8转成unicode,再逐个判断转换出来的字符,英文字母的高byte是0。可以在MSDN上找到MultiByteToWideChar的说明
第4个回答  2011-07-03
void GetWords( wchar_t *s,wchar_t *str1,wchar_t *str2 )
{
if (s == NULL || str1 == NULL || str2 == NULL) return;
do
{
if((*s>='a' && *s<='z') || (*s>='A' && *s<='Z'))
*str2++ = *s;
else
*str1++ = *s;
} while (*s++ != '\0');
}

int main()
{
wchar_t str1[256] = {0};//汉字
wchar_t str2[256] = {0};//字母
wchar_t *s = L"gfd师傅健身房sfsf算法啥地方sfjsjf是福建省jsf的飞";
GetWords(s,str1,str2);
system("pause");
return 0;
}追问

能给些注释吗,比起代码,我更像知道算法
wchar_t是什么

追答

如果你要显示中文最好用UNICODE,wchar_t是宽字,
我这个函数有点错误,
void GetWords( wchar_t *s,wchar_t *str1,wchar_t *str2 )
{
if (s == NULL || str1 == NULL || str2 == NULL) return;//安全检查
do
{
if((*s>=L'a' && *s=L'A' && *s<=L'Z'))//判断字符是否在a~z或A~Z之间,就是判断字符是否是字母
*str2++ = *s;//保存字母
else
*str1++ = *s;//保存其他(汉字)
} while (*s++ != '\0');
}

第5个回答  2011-07-03
汉字的第一个字母其asc码值》127
第6个回答  推荐于2016-06-07
这个问题太有建设性意义了,我决定去尝试一下

#include<iostream>
#include<fstream>
#include<cstring>
using namespace std;

void main()
{
ifstream infile("file.txt");
if(!infile)
cerr<<"fail to open the file"<<endl;
int num=0,total=0;
char a;
while(infile.get(a))
{
if(a>=0)
num++;
total++;
}
cout<<total<<'\t'<<num<<endl;
infile.close();
infile.open("file.txt",ifstream::in);
char *character=new char[total-num+1];
int i=0;
while(infile.get(a))
{
if(int(a)<0)
{
character[i]=a;
infile.get(a);
character[i+1]=a;
i+=2;
}
}

character[total-num]='\0';

cout<<"the character in the string is"<<character<<endl;

infile.close();
}
已经多次检验,都正确,思路是汉字第一个字节的ASCII值小于零,而且汉字占用两个字节本回答被提问者采纳
第7个回答  2011-07-05
//C好像不太好弄
//C++没问题
#include<iostream>
#include<fstream>
int main(){
ifstream fin("a.txt");
string s;
while(fin>>s){
cout<<s<<endl;
}
}
//把你准备好的文字放在a.txt里和编译的文件放在同一个目录下
另外,虚机团上产品团购,超级便宜
第8个回答  2011-07-04
先用MultiByteToWideChar把UTF-8转成unicode,再逐个判断转换出来的字符,英文字母的高byte是0。可以在MSDN上找到MultiByteToWideChar的说明
第9个回答  2011-07-03
void GetWords( wchar_t *s,wchar_t *str1,wchar_t *str2 )
{
if (s == NULL || str1 == NULL || str2 == NULL) return;
do
{
if((*s>='a' && *s<='z') || (*s>='A' && *s<='Z'))
*str2++ = *s;
else
*str1++ = *s;
} while (*s++ != '\0');
}

int main()
{
wchar_t str1[256] = {0};//汉字
wchar_t str2[256] = {0};//字母
wchar_t *s = L"gfd师傅健身房sfsf算法啥地方sfjsjf是福建省jsf的飞";
GetWords(s,str1,str2);
system("pause");
return 0;
}追问

能给些注释吗,比起代码,我更像知道算法
wchar_t是什么

追答

如果你要显示中文最好用UNICODE,wchar_t是宽字,
我这个函数有点错误,
void GetWords( wchar_t *s,wchar_t *str1,wchar_t *str2 )
{
if (s == NULL || str1 == NULL || str2 == NULL) return;//安全检查
do
{
if((*s>=L'a' && *s=L'A' && *s<=L'Z'))//判断字符是否在a~z或A~Z之间,就是判断字符是否是字母
*str2++ = *s;//保存字母
else
*str1++ = *s;//保存其他(汉字)
} while (*s++ != '\0');
}

第10个回答  2011-07-03
汉字的第一个字母其asc码值》127
相似回答
大家正在搜