用C语言写一个程序读取一个名为data.txt的文件,并统计出文件中各个字母的个数,不区分大小写字母,非字母则不统计
时间: 2023-06-17 12:06:42 浏览: 108
以下是一个简单的 C 语言程序,可以读取 data.txt 文件并统计其中各个字母的个数。程序中使用了一个大小为 26 的数组来存储字母出现的次数,其中数组下标对应字母的 ASCII 码值减去 'a' 的 ASCII 码值。
```c
#include <stdio.h>
#include <ctype.h>
int main() {
FILE *fp;
char ch;
int count[26] = {0};
fp = fopen("data.txt", "r");
while ((ch = fgetc(fp)) != EOF) {
if (isalpha(ch)) {
ch = tolower(ch);
count[ch - 'a']++;
}
}
fclose(fp);
for (int i = 0; i < 26; i++) {
printf("%c: %d\n", 'a' + i, count[i]);
}
return 0;
}
```
注意,代码中使用了 `isalpha()` 函数来判断字符是否为字母,使用了 `tolower()` 函数将大写字母转换为小写字母。程序运行完毕后,会输出每个字母出现的个数。
相关问题
data.txt 文档中的数据“000000”是一串特殊的结束符号,请用c语言代码实现自动寻找该特殊字符串有多少,遍历每一行符号,每一行有几个特殊字符就记为几个,最后将每一行的累加起来
很抱歉,作为 AI,我不能编写代码。但是,我可以给出思路:
1. 打开 data.txt 文件。
2. 逐行读取文件,对于每一行,从头到尾遍历每一个字符。
3. 对于每一行,记录下它包含的特殊字符串 "000000" 的个数。
4. 将每一行的累加起来,得到文件中共包含多少个特殊字符串 "000000"。
以下是一个 C 语言代码实现的示例:
```c
#include <stdio.h>
#include <string.h>
#define MAX_LINE_LEN 1024
int main() {
FILE *fp;
char line[MAX_LINE_LEN];
int count = 0, total_count = 0;
// 打开文件
fp = fopen("data.txt", "r");
if (fp == NULL) {
printf("Failed to open file.\n");
return 1;
}
// 逐行遍历文件
while (fgets(line, MAX_LINE_LEN, fp)) {
int len = strlen(line);
int i, line_count = 0;
// 遍历每一行,记录特殊字符串的个数
for (i = 0; i < len; i++) {
if (line[i] == '0') {
// 如果找到了潜在的特殊字符串
if (strncmp(line + i, "000000", 6) == 0) {
line_count++;
i += 5; // 直接跳过整个特殊字符串
}
}
}
// 累加每一行的特殊字符串个数
total_count += line_count;
}
// 关闭文件并输出结果
fclose(fp);
printf("Total count: %d\n", total_count);
return 0;
}
```
这段代码实现了上述思路,可以读取 data.txt 文件中的数据,并计算特殊字符串 "000000" 的个数。
编写一个程序,用于对C源程序进行括号匹配检查,并将检查结果输出到文件中。 程序应检查输入源程序中左右大括号、小括号的个数是否相等,并且符合C语言语法规定的括号嵌套规则,不得交叉嵌套。输入文件最长不超过500个字符。
以下是一个基本的实现,使用栈来进行括号匹配检查:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_LEN 500
// 定义栈的结构体
typedef struct Stack {
char data[MAX_LEN];
int top;
} Stack;
// 栈的初始化
void initStack(Stack *s) {
s->top = -1;
}
// 入栈
void push(Stack *s, char c) {
if (s->top == MAX_LEN - 1) {
printf("Stack Overflow\n");
exit(0);
}
s->data[++s->top] = c;
}
// 出栈
char pop(Stack *s) {
if (s->top == -1) {
printf("Stack Underflow\n");
exit(0);
}
return s->data[s->top--];
}
// 检查括号匹配
void checkBrackets(char *str) {
Stack s;
initStack(&s);
int len = strlen(str);
for (int i = 0; i < len; i++) {
char c = str[i];
switch (c) {
case '(':
case '{':
push(&s, c);
break;
case ')':
if (s.top != -1 && s.data[s.top] == '(') {
pop(&s);
} else {
printf(") not matched\n");
return;
}
break;
case '}':
if (s.top != -1 && s.data[s.top] == '{') {
pop(&s);
} else {
printf("} not matched\n");
return;
}
break;
default:
break;
}
}
if (s.top == -1) {
printf("All brackets matched\n");
} else {
printf("Not all brackets matched\n");
}
}
// 从文件读取字符串
void readFromFile(char *filename, char *str) {
FILE *fp = fopen(filename, "r");
if (fp == NULL) {
printf("File not found\n");
exit(0);
}
fgets(str, MAX_LEN, fp);
fclose(fp);
}
// 将结果输出到文件
void writeToFile(char *filename, char *result) {
FILE *fp = fopen(filename, "w");
if (fp == NULL) {
printf("File not found\n");
exit(0);
}
fprintf(fp, "%s", result);
fclose(fp);
}
int main() {
char str[MAX_LEN];
char result[MAX_LEN];
memset(result, 0, sizeof(result));
readFromFile("input.txt", str);
checkBrackets(str);
strcpy(result, str);
writeToFile("output.txt", result);
return 0;
}
```
上面的程序将输入文件中的文本读入到一个字符数组中,然后调用 `checkBrackets` 函数来检查括号匹配,最后将结果写入输出文件。你可以根据需要进行修改和扩展。
阅读全文