go 统计一个字符串中包含的汉字的个数

package main

import (
	"fmt"
	"unicode"
)

func main() {
	s := "这是个一包含汉字和英文的字符串, This is an apple"
	hzc := 0

	for _, v := range s {
		if unicode.Is(unicode.Han, v) {
			hzc++
		}
	}

	fmt.Printf("该字符串中找到中文个数是:%v\n", hzc)

}

统计一个字符串单词的个数,你可以使用指针来遍历字符串,并根据空格或其他分隔符判断单词的边界。下面是一个示例代码: ```c #include <stdio.h> int countWords(const char* str) { int count = 0; int isWord = 0; // 标记当前是否在单词 while (*str != '\0') { if (*str == ' ' || *str == '\t' || *str == '\n' || *str == '\r') { // 当前字符为空格或制表符或换行符或回车符,表示单词结束 isWord = 0; } else if (!isWord) { // 当前字符不是空格或制表符或换行符或回车符,且上一个字符是空格或制表符或换行符或回车符,表示进入一个新的单词 isWord = 1; count++; } str++; } return count; } int main() { const char* str = "Hello world! How are you?"; int wordCount = countWords(str); printf("Number of words: %d\n", wordCount); return 0; } ``` 在上面的代码,`countWords`函数接受一个字符指针作为参数,并使用指针遍历字符串。它使用`isWord`变量来标记当前是否在单词。当遇到空格、制表符、换行符或回车符时,将`isWord`设为0表示单词结束。当遇到非空格、制表符、换行符或回车符的字符,并且上一个字符是空格、制表符、换行符或回车符时,将`isWord`设为1表示进入一个新的单词,并且单词计数器`count`加1。最后,返回单词的个数。 在`main`函数,我们定义了一个字符串,并调用`countWords`函数来统计字符串的单词个数,并将结果打印出来。 请注意,这里的分隔符仅包括空格、制表符、换行符和回车符。如果你的需求还包括其他分隔符,你需要相应地修改代码来适应你的需求。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值