我有字符串str
char *str = "100.10b.100.100";
我想计算'.'
中str
的出现次数,最好是单行。 (如果可能没有循环)
我的方法是标准strchr
:
int i = 0;
char *pch=strchr(str,'.');
while (pch!=NULL) {
i++;
pch=strchr(pch+1,'.');
}
答案 0 :(得分:71)
这就是我做的方式(需要的变量数量最少):
for (i=0; s[i]; s[i]=='.' ? i++ : *s++);
答案 1 :(得分:22)
看,马,没有循环。
int c = countChars( s, '.' );
int countChars( char* s, char c )
{
return *s == '\0'
? 0
: countChars( s + 1, c ) + (*s == c);
}
但是,我实际上使用了一个循环,因为这是正确的控制结构。
答案 2 :(得分:21)
好的,非循环实现(是的,它意味着一个笑话)。
size_t CountChars(const char *s, char c)
{
size_t nCount=0;
if (s[0])
{
nCount += ( s[0]==c);
if (s[1])
{
nCount += ( s[1]==c);
if (s[2])
{
nCount += ( s[2]==c);
if (s[3])
{
nCount += ( s[3]==c);
if (s[4])
{
nCount += ( s[4]==c);
if (s[5])
{
nCount += ( s[5]==c);
if (s[6])
{
nCount += ( s[6]==c);
if (s[7])
{
nCount += ( s[7]==c);
if (s[8])
{
nCount += ( s[8]==c);
if (s[9])
{
nCount += ( s[9]==c);
if (s[10])
{
/* too long */
assert(0);
}
}
}
}
}
}
}
}
}
}
}
return nCount;
}
答案 3 :(得分:10)
没有循环会变得困难,因为没有标准的C库函数来执行此操作,您需要查看所有字符:)
我会采取明显的解决方案:
int i, count;
for (i=0, count=0; str[i]; i++)
count += (str[i] == '.');
如果必须,请随意将两行实际代码压缩成一个:)
答案 4 :(得分:5)
我仍然把它放在一个函数中,参数化源字符串和要搜索的字符。
int count_characters(const char *str, char character)
{
const char *p = str;
int count = 0;
do {
if (*p == character)
count++;
} while (*(p++));
return count;
}
答案 5 :(得分:3)
如果你热衷于单线(嗯,两个 - ):
size_t count = 0;
while(*str) if (*str++ == '.') ++count;
答案 6 :(得分:2)
//我想它应该有效。一行而没有循环。
int countChar(char *s, char letter) {
return ((*s) ? (((*s++ == letter)? 1:0)) + countChar (s, letter)): 0);
}
答案 7 :(得分:1)
没有循环的唯一方法是递归。以下内容是为了好玩,但建议 NOT 作为解决方案:
size_t CountChars(char* s, char c)
{
return *s ? ((c==*s) + CountChars(s+1)) : 0;
}
答案 8 :(得分:1)
我不喜欢goto,仍然,
int i=0,count=0;
char *str = "100.10b.100.100";
a:
if(str[i]=='.')
count++;
i++;
if(str[i])
goto a;
答案 9 :(得分:1)
每次运行此代码时,婴儿dijkstra都会哭泣:)
1
2
3
4 #include <ctype.h>
5 #include <stdio.h>
6 #include <stdlib.h>
7 #include <string.h>
8
9
10 size_t bytewise_pop_count(
11 unsigned char * bp, size_t l
12 ) {
13 if ( (bp) && (l) ) {
14 return bytewise_pop_count(bp+1, l-1) + (bp[0] ? 1 : 0);
15 }
16 return 0;
17 }
18
19 void mercilessly_complement_bytes(
20 unsigned char * bp, size_t l
21 ) {
22 /*
23 transform
24 0 -> 1
25 !0 -> 0
26 */
27 if ( (bp) && (l) ) {
28 bp[0] = bp[0] ? 0 : 1;
29 mercilessly_complement_bytes(bp+1, l-1);
30 }
31 }
32
33 void xor_bytes(
34 unsigned char * bp1, unsigned char * bp2, size_t l
35 ) {
36 /* stores result in bp2 */
37 if ( (bp1) && (bp2) && (l) ) {
38 bp2[0] ^= bp1[0];
39 xor_bytes(bp1+1, bp2+1, l-1);
40 }
41 }
42
43
44 int main(int argc, char * * argv) {
45 char c;
46 size_t count;
47 size_t l;
48 char * string;
49 char * t;
50
51 if (argc < 3) {
52 fprintf(stderr,
53 "\n"
54 "==> not enough arguments -- need char and string\n"
55 "\n"
56 );
57 return EXIT_FAILURE;
58 }
59
60 c = argv[1][0];
61 string = argv[2];
62
63 if ( l = strlen(string) ) {
64 t = malloc(l);
65 memset(t, c, l);
66 xor_bytes(string, t, l);
67 mercilessly_complement_bytes(t, l);
68 count = bytewise_pop_count(t, l);
69 free(t);
70 } else {
71 count = 0;
72 }
73
74 if ( isprint(c) ) {
75 printf(
76 "\n"
77 "==> occurences of char ``%c'' in string ``%s'': %zu\n"
78 "\n"
79 , c, string ? string : "<NULL>", count
80 );
81 } else {
82 printf(
83 "\n"
84 "==> occurences of char ``%hhu'' in string ``%s'': %zu\n"
85 "\n"
86 , c, string ? string : "<NULL>", count
87 );
88 }
89 return EXIT_SUCCESS;
90 }
答案 10 :(得分:1)
保留 str 完整的(以防以后使用)
for(i = 0, c = 0; str[i] != '\0'; (str[i] == '.')? c++: 0, i++);
如果您不关心 str 变量
for(c = 0; *str != '\0'; (*str == '.')? c++: 0, str++);
但是如您所见,它非常丑陋,所以我建议您这样做:
for(i = 0; str[i] != '\0'; i++)
{
if(str[i] == '.')
++c;
}
或
for(c = 0; *str != '\0'; str++)
{
if(*str == '.')
++c;
}
答案 11 :(得分:0)
使用 memchr:
size_t nOccurrences(const char* buffer, const char character, size_t bufferLength) {
size_t result = 0;
size_t residualLength = bufferLength;
do {
void* start = (void*)(buffer + bufferLength - residualLength);
void* occurrence = memchr(start, character, residualLength);
if(NULL == occurrence) {
break;
}
++result;
residualLength = bufferLength - ((char*)occurrence - buffer) - 1;
} while(1);
return result;
}