还有比这更短的吗?(计算C语言中一个字符在字符串中的出现次数)
Are there way shorter than this?(Counting number of occurrences of a char in a string in C)
int frequence(char *s,char c)
{
return *s ? (*s==c)+frequence(s+1,c) : 0;
}
还有比这更短的吗?
如果你指的是字符,可能。如果你指的是运行时间?那么你离最优解还差得很远。
递归比循环慢得多,如果精确地按照编写的方式编译,将会为足够大的字符串占用大量的堆栈空间。
好吧,如果函数必须命名为frequence
,那么迭代方法可能会缩短一些字符(当然,在删除不必要的空格之后):
int k=0; while (*s) k += c == *s++; return k;
使用STRCHR可以获得更好的运行时效率
int frequence(char *s,char c)
{
char *occur = s;
int result = 0;
while((occur = strchr(occur,c))){
result++;
occur++;
}
return result;
}
相关文章:
- 使用.find函数在c++中查找字符和另一个字符之间的大小
- 我已经建立了递归关系,它找到了两个字符串之间最长的连续公共字符串,我怎么能跳过其中一个字符串中的一个字符
- 使用动态分配将 char* 复制到另一个字符**
- 如何将一个结构的字符数组复制到结构的另一个字符数组中?
- 如何在不知道对应关系的情况下在字符串中搜索字符并将其分配给另一个字符?
- 如何检查一个字符是否与字符数组中的另一个字符匹配?
- C++:使用另一个字符将一个字符大写
- 我可以得到一个字符 * 到一个 std::sregex_iterator 匹配 str() 吗?
- 使用连续分隔符和空最后一个字符进行拆分
- 如何比较文件中包含的下一个字符
- 如何检查字符串中的最后一个字符是否是某个字符并将其从字符串中删除?(C++)
- 如何从文本文件中一次读取一个字符
- 将一个字符替换为字符串中更多数量的字符,而不删除C++中的其他字母
- 读取输入后,输出丢失了一个字符
- 比较最后一个字符,不区分大小写(带谓词?
- 如果一个字符,比如说"9",我减去"0",我在结果上使用 is 数字,我是真还是假
- 为什么 std::istream::gcount 返回的字符比预期的多一个字符
- 使用 fstream 在空格分隔文件中查看下一项(不仅仅是一个字符)的方法
- 使用 char 将一个字符数组分配给另一个字符数组时出现奇怪的行为
- 在弦乐器中删除最后一个字符