免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2145 | 回复: 8
打印 上一主题 下一主题

[其它] c语言创建单词本 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-05-19 22:48 |只看该作者 |倒序浏览
关于单词的头文件如下:
#ifndef __WORD_H__
#define __WORD_H__
typedef struct trans{
        char *trans;
        struct trans *next;
}Trans,*Ptrans;
typedef struct word{
        char *word;
        Ptrans head_trans;
        struct word *next;
}Word,*Pword;
Pword create_head();
Pword create_word(char *);
int create_trans(Pword,char *);
int print_trans(Pword);
#endif
关于单词的.C文件

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include"word.h"
Pword create_head()//创建空的单词
{
        Pword p = (Pword)malloc(sizeof(Word));
        if (p == NULL)
        {
                printf("creat word error\n");
                return NULL;
        }
        p->word = NULL;
        p->head_trans = NULL;
        p->next = NULL;
        return p;
}
Pword create_word(char *buff)//创建单词
{
        Pword p = (Pword)malloc(sizeof(Word));
        if(p == NULL)
        {
                printf("pword malloc error\n");
                return NULL;
        }
        p->word = (char*)malloc(sizeof(char) * (strlen(buff) + 1));
        strcpy(p->word,buff);
        p->next = NULL;
        p->head_trans = NULL;
        return p;
}
int create_trans(Pword pword,char *buff)//创建单词的一个解释
{
        int i = strlen(buff);
        Ptrans p = pword->head_trans;
        while(p != NULL)
        {
                p = p->next;
        }
        p = (Ptrans)malloc(sizeof(Trans));       
        p->trans = (char*)malloc(sizeof(char)*(i + 1));
        strcpy(p->trans,buff);
        p->next = NULL;
        return 0;
}


int print_trans(Pword pword)//打印单词所有解释
{
        if(pword == NULL)
        {
                printf("pword error\n");
                return -1;
        }
        int i = 1;
        Ptrans p = pword->head_trans;
        while(p != NULL)
        {
                printf("解释%d:%s\n",i,p->trans);
                i++;
                p = p->next;
        }
        return 0;
}
从词典中读取建立哈希链表如下:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include"hash.h"
Phash create_hash()
{
        Phash p = (Phash)malloc(sizeof(Hash));
        int i = 0;
        for(i = 0; i < 27; i++)
        {
                p->hash = create_head();
        }
        return p;
}
int hash_number(char *word)
{
        int i = word[0] - 'a';
        if(i < 0 || i > 25)
        {
                return 26;
        }
        return i;
}
int read_txt(Phash p)
{
        FILE *fp = fopen(FILE_PATH,"r");
        if(fp == NULL)
        {
                perror("open error");
                return -1;
        }
        char a[100] = {0};
        char b[1000] = {0};
        char c[500] = {0};
        int i = 0;
        int j = 0;
        int k = 0;
        fgetc(fp);
//        while(feof(fp) == 0)
//        {
                i = 0;
                do{
                        a = fgetc(fp);
                        i++;
                }while(a[i-1] != '\n');
                a[i-1] = '\0';
                Pword pword = create_word(a);
                Ptrans ptrans = (Ptrans)malloc(sizeof(Trans));
                int n = hash_number(a);
                for(i = 0; i < 6; i++)
                {
                        fgetc(fp);
                }
                fgets(b,1000,fp);
                i = strlen(b);
                b = '\0';
                k = 0;
                for(j = 0; j < i+1; j++)
                {       
                        if(b[j] == '@')
                        {
                                c[k] = '\0';
                                create_trans(pword,c);
                                k = 0;
                        }
                        else
                        {
                                c[k] = b[j];
                                k++;
                        }
                }
                create_trans(pword,c);
                print_trans(pword);
        #if 0
                insert_list(p->hash[n],pword);
#endif
                fgetc(fp);
//        }
        return 0;
}
问题就是在建立哈希链表的时候,红色代码执行时并没有打印出单词的解释,就是蓝色部分p等于 NULL了,没有进入while循环不知道为什么,按理说是要进入循环的,这是为什么??create_trans是可以执行的,求高人解答

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
2 [报告]
发表于 2014-05-20 08:11 |只看该作者
本帖最后由 amarant 于 2014-05-20 08:13 编辑

        p->word = NULL;
        p->head_trans = NULL;
        p->next = NULL;

给你大概看了下 没看到改写p->head_trans的代码

论坛徽章:
0
3 [报告]
发表于 2014-05-20 12:43 |只看该作者
int create_trans(Pword pword,char *buff)//创建单词的一个解释
{
        int i = strlen(buff);
        Ptrans p = pword->head_trans;
        while(p != NULL)
        {
                p = p->next;
        }
        p = (Ptrans)malloc(sizeof(Trans));        
        p->trans = (char*)malloc(sizeof(char)*(i + 1));
        strcpy(p->trans,buff);
        p->next = NULL;
        return 0;
}
这个就是给p->trans申请空间回复 2# amarant


   

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
4 [报告]
发表于 2014-05-20 14:57 |只看该作者
本帖最后由 amarant 于 2014-05-20 14:57 编辑

回复 3# futurebigniu


建议你用gdb之类的工具单步追踪下。

论坛徽章:
0
5 [报告]
发表于 2014-05-20 15:01 |只看该作者
我就是用gdb调试的,create_trans是可以执行的,执行到print_trans时while循环没有进入回复 4# amarant


   

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
6 [报告]
发表于 2014-05-20 15:12 |只看该作者
回复 5# futurebigniu


    主要看看前面你给我列出的函数为什么没有把链表设置好。我有时间再给你仔细看下程序吧

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
7 [报告]
发表于 2014-05-20 15:17 |只看该作者
本帖最后由 amarant 于 2014-05-20 15:19 编辑

回复 3# futurebigniu


    你没把p->next的值给赋值吧。链表没串起来,你自己看看是不是

应该有一个prev->next = p; 的操作

论坛徽章:
0
8 [报告]
发表于 2014-05-20 15:27 |只看该作者
这个是单链表,不是双链表,
while(p != NULL)
        {
                p = p->next;
        }
        p = (Ptrans)malloc(sizeof(Trans));        
        p->trans = (char*)malloc(sizeof(char)*(i + 1));
        strcpy(p->trans,buff);
        p->next = NULL;
这样有什么问题么?
回复 7# amarant


   

论坛徽章:
0
9 [报告]
发表于 2014-05-20 15:36 |只看该作者
哦,哦,好的,不胜感激回复 6# amarant


   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP