輪郭線追跡プログラム他の質問を参考にして輪郭線追跡プログラムを作成しましたが、trace関数部分が実行できません。教えて頂きたいです
#include <stdio.h> #include <stdlib.h>
#define NN 1600000
void trace(unsigned char image[], int im, int jm, int starti, int startj, int fcode[], int *num);
void findStartPt(unsigned char image[], int im, int jm, int *starti, int *startj);
int main(int argc, char *argv[]) {
int im,jm; char fname[100]; unsigned char image[NN];
int i,j;
int th;
int col;
int starti, startj;
int num=0;
int fcode[NN];
printf("元の画像ファイル名を入れてください: \n"); scanf("%s",fname);
read_pnm(fname, &im, &jm, &col, image); findStartPt(image,im,jm,&starti,&startj);
printf("%d %d\n", starti, startj);
num=1;
trace(image,im,jm,starti, startj, fcode, &num);
} void trace(unsigned char image[], int im, int jm, int starti, int startj, int fcode[], int *num) {
int x,y,i;
x = starti;
y=startj;
num=0;
while(x<=im && y<=jm){
if(image[y*im+x]==0){ if(image[(y-1)*im+(x-1)]==0){
*fcode=5; x=x-1; y=y-1; num++;
} else{
if(image[(y-1)*im+x]==0){
*fcode=6; y=y-1; num++;
} else{
if(image[(y-1)*im+(x+1)]==0){
*fcode=7; x=x+1; y=y-1; num++; }
else{
if(image[y*im+(x+1)]==0){
*fcode=0; x=x+1; num++;
} else{
if(image[y*im+(x-1)]==0){
*fcode=4; x=x-1; num++;
} else{
if(image[(y+1)*im+(x-1)]==0){
*fcode=3;
x=x-1;
y=y+1;
num++;
}else{ if(image[(y+1)*im+x]==0){
*fcode=2; y=y+1; num++; }
else{
if(image[(y+1)*im+(x+1)]==0){
*fcode=1;
x=x+1;
y=y+1;
num++;
}
}
}
}
}
}
} void findStartPt(unsigned char image[], int im, int jm, int *starti, int *startj) {
int i, j;
int dist;
int dmin=im*im+jm*jm;
// find start point
for (j=0;j<jm;++j) {
for (i=0;i<im;++i) {
if (image[i+j*im]==255) {
dist=i*i+j*j;
if (dist<dmin) {
*starti=i; *startj=j; dmin=dist;
}
}
}
}
}
void read_pnm(char filename[],int *im,int *jm, int *col, unsigned char image[]) {
int i,j; FILE *fp; char buf[10000]; if((fp=fopen(filename,"rb"))==NULL) {
printf("file %s can not open ",filename); exit(0);
}
check_pnm(buf,fp,im,jm,col); fread(image,sizeof(unsigned char),(*im)*(*jm)*(*col),fp); fclose(fp); }
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
>trace関数部分が実行できません。
とはどの様な事象なのかを書かないと駄目ですね。
コンパイルエラーなのか実行時にエラーになるのか何もせず次へ行くのかや、メッセージが出る(その内容)のかで無いのか。
文字数制限で入力できませんでした。
エラーが起きず、
他の関数部分のprintfだけ出力されて
trace関数部分は何も実行されずに終了します。
trace関数のいろいろな部分にprintfを入れて調べたところ、whileの中が実行されていないみたいでした。
No.1
- 回答日時:
関数がちゃんと閉じかっこされてないような。
ネストが浅くなるようにコードを書いてみては。(行頭空白を全角空白にしてみたものが以下)
#include <stdio.h> #include <stdlib.h>
#define NN 1600000
void trace(unsigned char image[], int im, int jm, int starti, int startj, int fcode[], int *num);
void findStartPt(unsigned char image[], int im, int jm, int *starti, int *startj);
int main(int argc, char *argv[]) {
int im,jm; char fname[100]; unsigned char image[NN];
int i,j;
int th;
int col;
int starti, startj;
int num=0;
int fcode[NN];
printf("元の画像ファイル名を入れてください: \n"); scanf("%s",fname);
read_pnm(fname, &im, &jm, &col, image); findStartPt(image,im,jm,&starti,&startj);
printf("%d %d\n", starti, startj);
num=1;
trace(image,im,jm,starti, startj, fcode, &num);
}
void trace(unsigned char image[], int im, int jm, int starti, int startj, int fcode[], int *num) {
int x,y,i;
x = starti;
y=startj;
num=0;
while(x<=im && y<=jm){
if(image[y*im+x]==0){
if(image[(y-1)*im+(x-1)]==0){
*fcode=5; x=x-1; y=y-1; num++;
} else{
if(image[(y-1)*im+x]==0){
*fcode=6; y=y-1; num++;
} else{
if(image[(y-1)*im+(x+1)]==0){
*fcode=7; x=x+1; y=y-1; num++;
} else{
if(image[y*im+(x+1)]==0){
*fcode=0; x=x+1; num++;
} else{
if(image[y*im+(x-1)]==0){
*fcode=4; x=x-1; num++;
} else{
if(image[(y+1)*im+(x-1)]==0){
*fcode=3;
x=x-1;
y=y+1;
num++;
}else{
if(image[(y+1)*im+x]==0){
*fcode=2; y=y+1; num++;
} else{
if(image[(y+1)*im+(x+1)]==0){
*fcode=1;
x=x+1;
y=y+1;
num++;
}
}
}
}
}
}
}
void findStartPt(unsigned char image[], int im, int jm, int *starti, int *startj) {
int i, j;
int dist;
int dmin=im*im+jm*jm;
// find start point
for (j=0;j<jm;++j) {
for (i=0;i<im;++i) {
if (image[i+j*im]==255) {
dist=i*i+j*j;
if (dist<dmin) {
*starti=i; *startj=j; dmin=dist;
}
}
}
}
}
void read_pnm(char filename[],int *im,int *jm, int *col, unsigned char image[]) {
int i,j; FILE *fp; char buf[10000]; if((fp=fopen(filename,"rb"))==NULL) {
printf("file %s can not open ",filename); exit(0);
}
check_pnm(buf,fp,im,jm,col); fread(image,sizeof(unsigned char),(*im)*(*jm)*(*col),fp); fclose(fp);
}
ネストという言葉を初めて聞きました…
ありがとうございます。
実行させてみたのですが、うまくいかなかったです。
ありがとうございます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# c言語の問題の説明、各所ごとに 5 2023/07/26 11:03
- C言語・C++・C# 質問です 下記のコードを分かりやすく解説お願いします 初心者です #include ‹stdio.h 3 2022/05/26 22:03
- C言語・C++・C# プログラミング c言語 4 2023/03/07 01:05
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- C言語・C++・C# C言語 共用体について コマンドライン引数で値を2つ入力したときに、argv[2]の値をUNI u1 4 2022/04/25 20:34
- C言語・C++・C# c言語 プログラムのエラー 1 2023/02/11 20:31
- C言語・C++・C# C言語でif文が予想と違う動きをする件について7 4 2023/03/20 00:26
- C言語・C++・C# 並列プログラミングのπ計算について 1 2022/07/16 22:30
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- C言語・C++・C# プログラミングの授業の課題です 1 2023/01/17 22:15
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
C言語での引数の省略方法
-
【C++】関数ポインタの使い方
-
「指定されたキャストは有効で...
-
#define _CRT_SECURE_NO_WARNIN...
-
複数桁10進数の*桁目だけを抽出...
-
「{ } で囲むだけ」は正しい?
-
実数の整数部,小数部の取得
-
c言語の配列を使ってサイコロを...
-
if と配列の組み合わせ
-
C言語で行列の積を計算できるよ...
-
入力を待たずにstdinの監視をし...
-
C言語 エラーの原因がわからな...
-
C++でvectorにテキストファイル...
-
ラップ関数とはどんなものですか?
-
数字列を3桁ごとにカンマで区切...
-
return 1L
-
PowerShellがうまくいかない
-
C言語の配列をC++のvectorに高...
-
野球の対戦成績のテーブル表示...
-
部分行列の抜き出し(C言語)
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「指定されたキャストは有効で...
-
C言語での引数の省略方法
-
#define _CRT_SECURE_NO_WARNIN...
-
複数桁10進数の*桁目だけを抽出...
-
【C++】関数ポインタの使い方
-
C言語 エラーの原因がわからな...
-
c++でテンプレートのコードでわ...
-
(int *)の意味
-
ラップ関数とはどんなものですか?
-
数字列を3桁ごとにカンマで区切...
-
c言語のリダイレクトによる円...
-
比較回数と交換回数表示について
-
実数の整数部,小数部の取得
-
if と配列の組み合わせ
-
構造体の勉強中です 合計点の高...
-
PowerShellがうまくいかない
-
c言語の配列を使ってサイコロを...
-
課題でつまってます・・・
-
C言語のサイコロシミュレート
-
エラー 添字が付けられた値が、...
おすすめ情報