关于C语言遍历中英文字符串时的输出问题

问题:https://ask.csdn.net/questions/7560143?answer=53582941
在这里插入图片描述
在这里插入图片描述

解答:
普通汉字一个字符占两个字节,字母占一个字节。 你在变换的时候,本来是两个字节表示的汉字,给拆开了。 显示的就是乱码

这里提供一种解决思路,判断当前是否为中文,如果是中文,那么接下来的两个字节视为一个整体。代码参考如下:

void func(const char* str)
{
    
    
    int len = strlen(str);
    for (int i = 0; i < len; i++)
    {
    
    
        int idx = i;
        for(int j = 0; j < len; j++)
        {
    
    
            if (str[idx % len] < 0)
            {
    
    
                printf("%c%c", str[idx % len],str[ (idx+1)% len]);
                idx+=2;
                j++;
            }
            else
            {
    
    
                printf("%c", str[idx % len]);
                idx++;
            }
        }
        printf("\n");
        if (str[i % len] < 0) i++;
    }
}
 
int main()
{
    
    
    //const char* str = "This is a test.";
    //const char* str = "这是一个测试用例。";
    const char* str = "测试用例: abcdefg.";
    func(str);
    return 0;
}

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_43919932/article/details/123937379