m0_73330081 2023-02-14 11:13 采纳率: 40%
浏览 31
已结题

不用char数组,不给限定字符串长度实现结果


#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define MAX 20

struct node {
    char word[MAX];
    int count;
    struct node *next;
};

typedef struct node nodes;
nodes *head = NULL;

nodes *search(char *word) {
    nodes *p = head;
    while (p != NULL) {
        if (strcmp(p->word, word) == 0) {
        return p;
        }
    p = p->next;
    }
    return NULL;
}

void insert(char *word) {
    nodes *p = search(word);
    if (p == NULL) {
        nodes *new_node = (nodes *)malloc(sizeof(nodes));
        strcpy(new_node->word, word);
        new_node->count = 1;
        new_node->next = head;
        head = new_node;
    } else {
        p->count++;
    }
}

int main() {
    char word[MAX];
    while (scanf("%s", word) != EOF) {
        if (strcmp(word, "count-end") == 0) {
        break;
        }
        insert(word);
    }

nodes *p = head;
while (p != NULL) {
    printf("%s出现了%d次\n", p->word, p->count);
    p = p->next;
    }
    return 0;
}
  • 写回答

3条回答 默认 最新

  • 快乐鹦鹉 2023-02-14 11:41
    关注
     
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
     
    struct node {
        char *word;
        int count;
        struct node *next;
    };
     
    typedef struct node nodes;
    nodes *head = NULL;
     
    nodes *search(char *word) {
        nodes *p = head;
        while (p != NULL) {
            if (strcmp(p->word, word) == 0) {
            return p;
            }
        p = p->next;
        }
        return NULL;
    }
     
    void insert(char *word) {
        nodes *p = search(word);
        if (p == NULL) {
            nodes *new_node = (nodes *)malloc(sizeof(nodes));
            int len = strlen(word);
            new_node->word = (char*)malloc(sizeof(char)*len);
            strcpy(new_node->word, word);
            new_node->count = 1;
            new_node->next = head;
            head = new_node;
        } else {
            p->count++;
        }
    }
     
    int main() {
        char word[MAX];
        while (scanf("%s", word) != EOF) {
            if (strcmp(word, "count-end") == 0) {
            break;
            }
            insert(word);
        }
     
    nodes *p = head;
    while (p != NULL) {
        printf("%s出现了%d次\n", p->word, p->count);
        p = p->next;
        }
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 2月22日
  • 已采纳回答 2月14日
  • 创建了问题 2月14日

悬赏问题

  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 关于大棚监测的pcb板设计
  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器
  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)
  • ¥15 Vue3地图和异步函数使用