
今学校で二分探索木を勉強しています。二分探索木に要素を挿入したいのですが、うまくいかないのでアドバイスをいただけないでしょうか。ファイル中の英文を単語に分けてその出現頻度をカウントするプログラムです。とりあえず二分探索木を作るところまではなんとか完成させたいです。
#include <stdio.h>
#include <stdlib.h>
#include<string.h>
#include <ctype.h>
typedef struct node Node;
struct node{
char *word;
int count;
Node *left,*right;
};
Node *root=NULL;
Node *compose(FILE *fp);
void inorder(Node *p);
int main(int argc, char *argv[])
{
FILE *fp;
Node *new;
fp=fopen(argv[1],"r");
if(fp==NULL){
puts("ファイルを開けません");
return(-1);
}
new=(Node *)malloc(sizeof(Node *));
new=compose(fp);
inorder(new);
return (0);
}
Node *compose(FILE *fp)
{
Node **p,*new;
char buf[20];
p=&root;
while(fscanf(fp,"%[-a-z-A-Z0-9_]",buf)!=EOF){
while(*p!=NULL){
(*p)->count=0; /*countを0で初期化したいけどwhileの外にこの1行を出すとエラーが出る*/
buf[0]=tolower(buf[0]);
strdup(buf);
if(strcasecmp(buf,(*p)->word)==0){ /*if文にしかはいらない…*/
(*p)->count++;
printf("%d\n",(*p)->count);
}else if(strcasecmp(buf,(*p)->word)<0){
p=&(*p)->left;
}else{
p=&(*p)->right;
}
}
new=(Node *)malloc(sizeof(Node *));
new->left=NULL;
new->right=NULL;
new->word=buf;
*p=new;
fscanf(fp,"%*[^-a-z-A-Z0-9_]");
}
return(new);
}
void inorder(Node *p)
{
if(p==NULL)
return;
printf("%s",p->word);
if(p->count!=0){
printf("%d",p->count);
}
inorder(p->right);
inorder(p->left);
}
No.4ベストアンサー
- 回答日時:
なんとなく動くようにしてみました。
参考にしていただければ。。#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
typedef struct node Node;
struct node{
char *word;
int count;
Node *left,*right;
};
Node *root=NULL;
void compose(FILE *fp);
void inorder(Node *p);
void strlower(char *s);
int main(int argc, char *argv[]) {
FILE *fp;
Node *new;
fp=fopen(argv[1],"r");
if(fp==NULL){ puts("ファイルを開けません"); return(-1); }
compose(fp);
inorder(root);
return (0);
}
/* 文字列を小文字にする */
void strlower(char *s) {
while(*s!=NULL) { *s=tolower(*s); s++; }
}
/* 木を作る */
void compose(FILE *fp) {
Node **p,*new;
char buf[256];
while(1) {
fscanf(fp,"%[^a-zA-Z0-9]",buf); /* 英数字がくるまで読み飛ばす */
if (fscanf(fp,"%[a-zA-Z0-9]",buf)==EOF) break; /* ファイルから単語らしきものを読み込む */
strlower(buf); /* 文字列を小文字化 */
if (root==NULL) { /* 最初の単語ならすぐ登録 */
new=(Node *)malloc(sizeof(Node));
new->left=NULL; new->right=NULL; new->word=strdup(buf); new->count=1;
root=new;
} else { /* 最初でなければ大小比較して挿入場所を探す */
*p=root; /* 注目ノードを根に設定 */
while(1){
if(strcmp(buf,(*p)->word)==0){ /* 同じデータがあればカウントアップして終わり */
(*p)->count++; break;
} else if(strcmp(buf,(*p)->word)<0){ /* 新単語が小さければ左を見る */
if ((*p)->left==NULL) { /* 子がなければ新規登録 */
new=(Node *)malloc(sizeof(Node));
new->left=NULL; new->right=NULL; new->word=strdup(buf); new->count=1;
(*p)->left=new; break;
} else { /* 左を探す */
*p=(*p)->left;
}
} else { /* 新単語が大きければ右を見る */
if ((*p)->right==NULL) { /* 子がなければ新規登録 */
new=(Node *)malloc(sizeof(Node));
new->left=NULL; new->right=NULL; new->word=strdup(buf); new->count=1;
(*p)->right=new; break;
}else{ /* 右を探す */
*p=(*p)->right;
}
}
}
}
}
}
/* 小さい順に表示 */
void inorder(Node *p) {
if (p==NULL) return;
inorder(p->left);
printf("%s %d\n",p->word, p->count);
inorder(p->right);
}
お礼が遅くなってしまい申し訳ありません。
友人と相談して関数をもう一つ付け加えたら挿入できるようになりました。JaritenCatさんのソースもまた勉強の材料にさせていただきます。ありがとうございました!
No.3
- 回答日時:
> if(strcasecmp(buf,(*p)->word)==0){ /*if文にしかはいらない…*/
構造体のメンバーwordには適切な値が入っていますか?
> *p=new;
> fscanf(fp,"%*[^-a-z-A-Z0-9_]");
ここのfscanf()の意味合いがわかりません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ファイルに行番号を追加
-
複数ファイルの同時読み込みの...
-
C言語 連番データの読み込み
-
「Aに対するBの割合」と「Aに対...
-
Enterキーを押されたら次の処理...
-
Aの値からBの値を除するとは??
-
有効数字について 以前質問をし...
-
信頼区間の1.96や1.65ってどこ...
-
std::set<int> で、ある値が何...
-
20'(角度)の計算がわかりま...
-
数学で、定数aの値を求めよって...
-
do-while文が禁止される理由
-
正の数aは4の倍数で、7でわると...
-
3桁区切(コンマ)記号をつけ...
-
プログラムでの数字につく”f”の...
-
未解決の外部シンボル _printf...
-
ループを途中で抜けたいのですが。
-
エディットコントロール入力時...
-
関数におけるif文とreturn文に...
-
”あいうえお” を ”おえういあ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
テキストファイル内に対して, ...
-
複数ファイルの同時読み込みの...
-
C言語でファイル読み書きを早く...
-
ファイル出力で改行を入れたい!
-
なぜCSQとCIP形式ではコ...
-
fopenでファイル名に、変数を使...
-
c言語でのfscanfについて
-
C言語にてXMLファイルから任意...
-
_popen() のエラー取得
-
数値のみ抽出(C言語)
-
ランダムアクセスができない
-
C言語でのCSVソートとデータ抽...
-
C言語 連番データの読み込み
-
ファイルの作成・書き込み・読...
-
fscanfでループしてしまう。
-
ファイルへの書込み処理が異常...
-
ファイルを読み込んで条件式を...
-
CSVファイルを読み込み構造体の...
-
C言語でセグメンテーションエ...
-
C言語について
おすすめ情報