用c语言实现统计一个给定字符串中指定的字符出现的次数 输入描述 测试输入包含若干测试用例,每个测试用例包含2行,第1行为一个长度不超过5的字符串,第2行为一个长度不超过80的字符串。注意这里的字符串包含空格,即空格也可能是要求被统计的字符之一。当读到’#'时输入结束,相应的结果不要输出。 输出描述 对每个测试用例,统计第1行中字符串的每个字符在第2行字符串中出现的次数,按如下格式输出:其中ci是第1行中第i个字符,ni是ci出现的次数。 用例输入 1 I THIS IS A TEST i ng this is a long test string # 用例输出 1 I 2 i 3 5 n 2 g 2
时间: 2023-06-02 16:06:05 浏览: 55
#’时输入结束。输出描述 对于每个测试用例,输出指定字符出现的次数。
实现思路:
首先需要明确的是,要统计的指定字符可能是一个空格,所以在读入第二行字符串时需要使用 fgets() 函数,否则会在空格处停止读入。
统计字符出现次数的方法有多种,这里提供一种比较简单的做法:遍历字符串,对于每个字符,判断它是否等于要统计的字符,如果是,计数器加 1。最后输出计数器即可。
代码如下:
相关问题
用c语言实现统计一个给定字符串中指定的字符出现的次数 输入描述 测试输入包含若干测试用例,每个测试用例包含2行,第1行为一个长度不超过5的字符串,第2行为一个长度不超过80的字符串。注意这里的字符串包含空格,即空格也可能是要求被统计的字符之一。当读到’#'时输入结束,相应的结果不要输出。 输出描述 对每个测试用例,统计第1行中字符串的每个字符在第2行字符串中出现的次数,按如下格式输出:其中ci是第1行中第i个字符,ni是ci出现的次数。
\0’时输入结束。输出描述 对于每个测试用例,输出该字符串中指定字符出现的次数。每个输出占一行。
解题思路:遍历给定字符串,判断每个字符是否等于指定字符,若相等则计数器加1,最后输出计数器的值即可。
示例代码:
#include <stdio.h>
#include <string.h>
int main()
{
char s1[6], s2[81], c; // s1:指定字符;s2:给定字符串;c:当前遍历到的字符
int n, len, count; // n:测试用例数;len:给定字符串的长度;count:指定字符出现的次数
scanf("%d", &n);
while(n--)
{
scanf("%s", s1);
scanf(" %[^\n]", s2); // 注意这里要加一个空格,否则会读取到回车
len = strlen(s2);
count = 0;
for(int i = 0; i < len; i++)
{
c = s2[i];
if(c == s1[0]) // 判断当前字符是否等于指定字符
count++;
}
printf("%d\n", count);
}
return 0;
}
给定一个s字符串和一个n字符串,在s字符串中找出n字符串出现的第一个位置(从0开始)。如果不存在,则返回 -1(需要给出多个测试用例,证明算法的正确性)用C语言实现
好的,以下是用C语言实现的代码:
```c
#include <stdio.h>
#include <string.h>
int findSubstring(char* s, char* n) {
int s_len = strlen(s);
int n_len = strlen(n);
if (n_len > s_len) {
return -1;
}
for (int i = 0; i <= s_len - n_len; i++) {
int j;
for (j = 0; j < n_len; j++) {
if (s[i+j] != n[j]) {
break;
}
}
if (j == n_len) {
return i;
}
}
return -1;
}
int main() {
char s1[] = "hello world";
char n1[] = "world";
int r1 = findSubstring(s1, n1);
printf("s1: %s\n", s1);
printf("n1: %s\n", n1);
printf("r1: %d\n", r1);
char s2[] = "hello world";
char n2[] = "goodbye";
int r2 = findSubstring(s2, n2);
printf("s2: %s\n", s2);
printf("n2: %s\n", n2);
printf("r2: %d\n", r2);
char s3[] = "hello world";
char n3[] = "o w";
int r3 = findSubstring(s3, n3);
printf("s3: %s\n", s3);
printf("n3: %s\n", n3);
printf("r3: %d\n", r3);
return 0;
}
```
输出结果为:
```
s1: hello world
n1: world
r1: 6
s2: hello world
n2: goodbye
r2: -1
s3: hello world
n3: o w
r3: 4
```
可以看出,代码能够正确地找出给定的字符串中子串的位置,可以通过多个测试用例,证明算法的正确性。