char str[1000],ch; int a[150]={0},b,c; fgets(str,1000,stdin); int i,j,k; for(i=0;i<strlen(str);i++) { b=str[i]; a[b]++; } int MAX=a[0]; for(i=0;i<150;i++) { if(a[i]>MAX) MAX=a[i],c=i; } ch=c; printf("%c %d",ch,MAX);
时间: 2024-04-02 14:31:15 浏览: 75
这是一段完整的 C 语言代码,它实现了统计字符串中出现次数最多的字符及其出现次数的功能。具体来说,这段代码会先读取用户输入的字符串并存储在 `str` 变量中,然后使用之前介绍的方法统计字符串中每个字符出现的次数,并将结果存储在数组 `a` 中。接着,代码会遍历数组 `a`,找到出现次数最多的字符及其出现次数,并将其分别存储在变量 `c` 和 `MAX` 中。最后,代码会将最多出现的字符输出到屏幕上,并输出该字符出现的次数。
需要注意的是,为了使用这段代码,需要包含头文件 `stdio.h` 和 `string.h`,并保证输入的字符串长度不超过 999 个字符。
相关问题
#include<stdio.h> int find_char(const char*str,const char ch) { const char*p; for(p==str;*p!='\0';p++) { if(*p=='ch') return p-str; } return -1; } int main() { char str[100],ch; printf("Input str:\n"); gets(str); printf("Input ch:\n"); ch=getchar(); printf("position=%d\n",find_char(str,ch)); return 0; }错误在哪
这段代码中存在以下错误:
1. 在 find_char 函数中,指针变量 p 没有被正确初始化,应该改为 `const char *p = str;`。
2. 在 if 语句中,应该使用 ch 而不是 'ch',因为 'ch' 是一个字符数组,而 ch 是一个字符变量。因此,if 语句应该改为 `if (*p == ch)`。
3. 在主函数中,gets 函数已经被弃用,应该改为使用 fgets 函数。此外,在输入 ch 时,应该在输入后加上一个 getchar(),以消耗输入缓冲区中的换行符。
改正后的代码如下:
```
#include <stdio.h>
int find_char(const char* str, const char ch) {
const char* p = str;
for (; *p != '\0'; p++) {
if (*p == ch)
return p - str;
}
return -1;
}
int main() {
char str[100], ch;
printf("Input str:\n");
fgets(str, sizeof(str), stdin);
printf("Input ch:\n");
ch = getchar();
getchar(); // 消耗输入缓冲区中的换行符
printf("position=%d\n", find_char(str, ch));
return 0;
}
```
将一下java代码转成c语言:import java.util.; public class Main { public static boolean judge(char c1,char c2) { char ch[] = {'#','+','-','','/','%','(',')'}; int num1 = 0,num2 = 0; for(int i = 0;i <= 7;i ++) { if(ch[i] == c1) num1 = i; if(ch[i] == c2) num2 = i; } if(num1 > num2) return true; return false; } public static int calculation(int t1,int t2,char c) { if(c == '+') return t2 + t1; else if(c == '-') return t2 - t1; else if(c == '*') return t2 * t1; else if(c == '%') return t2 % t1; else return t2 / t1; } public static void main(String[] args) { Scanner sc = new Scanner(System.in); String s = sc.nextLine(); Stack<Integer> stk_int = new Stack<>(); Stack<Character> stk_str = new Stack<>(); int index = 0; stk_str.push('#'); for(int i = 0;i < s.length();i ++) { if(s.charAt(i) < '0' || s.charAt(i) > '9') { if(index != i) stk_int.push(Integer.parseInt(s.substring(index,i))); index = i+1; boolean flag = false; while(flag == false) { if (judge(s.charAt(i),stk_str.peek())) { stk_str.push(s.charAt(i)); if(stk_str.peek() == '(' ) stk_str.push('#'); if( stk_str.peek() == ')') { stk_str.pop(); while(stk_str.peek()!='#') { stk_int.push(calculation(stk_int.pop(),stk_int.pop(),stk_str.pop())); } stk_str.pop(); stk_str.pop(); } flag = true; } else { stk_int.push(calculation(stk_int.pop(),stk_int.pop(),stk_str.pop())); } } } if(index != s.length() && i == s.length()-1) stk_int.push(Integer.parseInt(s.substring(index,s.length()))); } while(!stk_int.isEmpty() && stk_str.peek()!= '#') { stk_int.push(calculation(stk_int.pop(),stk_int.pop(),stk_str.pop())); } System.out.println(stk_int.pop()); } }
以下是将 Java 代码转换为 C 语言代码的结果:
```c
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
#include <string.h>
bool judge(char c1, char c2) {
char ch[] = {'#', '+', '-', '*', '/', '%', '(', ')'};
int num1 = 0, num2 = 0;
for (int i = 0; i <= 7; i++) {
if (ch[i] == c1) num1 = i;
if (ch[i] == c2) num2 = i;
}
if (num1 > num2) return true;
return false;
}
int calculation(int t1, int t2, char c) {
if (c == '+') return t2 + t1;
else if (c == '-') return t2 - t1;
else if (c == '*') return t2 * t1;
else if (c == '%') return t2 % t1;
else return t2 / t1;
}
int main() {
char s[1000];
fgets(s, 1000, stdin);
s[strlen(s) - 1] = '\0';
int index = 0;
int stk_int[1000], top_int = -1;
char stk_str[1000], top_str = '#';
for (int i = 0; i < strlen(s); i++) {
if (s[i] < '0' || s[i] > '9') {
if (index != i) {
stk_int[++top_int] = atoi(&s[index]);
}
index = i + 1;
bool flag = false;
while (flag == false) {
if (judge(s[i], top_str)) {
stk_str[++top_str] = s[i];
if (top_str == '(') stk_str[++top_str] = '#';
if (top_str == ')') {
top_str--;
while (top_str != '#' && top_str != '(') {
stk_int[top_int - 1] = calculation(stk_int[top_int], stk_int[top_int - 1], stk_str[top_str--]);
top_int--;
}
top_str--;
}
flag = true;
} else {
stk_int[top_int - 1] = calculation(stk_int[top_int], stk_int[top_int - 1], stk_str[top_str--]);
top_int--;
}
}
}
if (index != strlen(s) && i == strlen(s) - 1) {
stk_int[++top_int] = atoi(&s[index]);
}
}
while (top_int >= 0 && top_str != '#') {
stk_int[top_int - 1] = calculation(stk_int[top_int], stk_int[top_int - 1], stk_str[top_str--]);
top_int--;
}
printf("%d\n", stk_int[top_int--]);
return 0;
}
```
需要注意的是,Java 代码中使用了 Scanner 类来接收用户的输入,在 C 语言中需要使用 fgets 函数。此外,Java 中的 Stack 类可以使用数组来实现栈的功能。需要注意的是,C 语言中数组下标从 0 开始计数,而 Java 中数组下标从 1 开始计数,因此在转换过程中需要进行相应的调整。
阅读全文