用c语言实现统计一个给定字符串中指定的字符出现的次数 输入描述 测试输入包含若干测试用例,每个测试用例包含2行,第1行为一个长度不超过5的字符串,第2行为一个长度不超过80的字符串。注意这里的字符串包含空格,即空格也可能是要求被统计的字符之一。当读到’#'时输入结束,相应的结果不要输出。 输出描述 对每个测试用例,统计第1行中字符串的每个字符在第2行字符串中出现的次数,按如下格式输出:其中ci是第1行中第i个字符,ni是ci出现的次数。
时间: 2023-06-02 11:06:07 浏览: 107
#’时,输入结束,程序应该退出。
以下是C语言实现统计指定字符出现次数的代码示例:
#include <stdio.h>
#include <string.h>
int main() {
char c; //指定字符
char str[81]; //输入字符串
int count; //字符出现次数
while (1) {
scanf("%c", &c);
if (c == '#') break; //输入结束
getchar(); //清除输入缓冲
fgets(str, 81, stdin); //读取输入字符串
count = 0; //计数器清零
for (int i = 0; i < strlen(str); i++) {
if (str[i] == c) count++;
}
printf("%d\n", count); //输出结果
}
return 0;
}
程序的算法非常简单,首先读入一个指定字符,如果是’#’则表示输入结束,程序退出。然后读取一个字符串,并遍历每个字符,统计指定字符出现的次数,最后输出结果即可。需要注意的是,在读取字符和字符串时,由于输入缓冲的问题,需要使用getchar和fgets函数分别清除输入缓冲和读取输入字符串。
相关问题
用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
```
可以看出,代码能够正确地找出给定的字符串中子串的位置,可以通过多个测试用例,证明算法的正确性。
阅读全文