質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

4回答

1016閲覧

ループでカウントさせてた変数がループを抜けると格納された値が変わってしまいます。

apeirogon0813

総合スコア117

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2019/01/31 07:24

編集2019/01/31 07:37

前提・実現したいこと

以下のプログラムでループ内で変数count++;としてインクリメントするのですが
ループを抜けた後にprintfで確認すると格納されている値が変わってしまいます。

発生している問題・エラーメッセージ

count = 0 count = 1 count = 2 count = 3 count = 4 count = 5 count = 6 count = 7 count = 8 count = 9 count = 10 count = 11 count = 12 count = 13 count = 14 count = 15 count = 16 count = 4339 ← ループを抜けた後の値

該当のソースコード

C

1#include<stdio.h> 2#include<stdlib.h> 3#include<string.h> 4#define SETMAX 10600 5char buf[256]; 6 7struct station { int eki; char name[64], rosen[64]; }; 8int main() { 9 int i=0, ekisize, l, r, m; 10 int num[10], count = 0; 11 struct station *ekidata[SETMAX], *st; 12 char ekiname[64]; 13 FILE *fp = fopen("./ekisen.txt","r"); 14 while(fgets(buf,sizeof(buf),fp)!=NULL && i<SETMAX) { 15 st = (struct station*) malloc(sizeof(struct station)); 16 sscanf(buf, "%[^:]:%d:%[^\n]*c", st->name, &st->eki, st->rosen); 17 ekidata[i] = st; 18 ++i; 19 } 20 fclose(fp); 21 ekisize = i; 22 scanf("%[^\n]%*c",ekiname); 23 l=0; r=ekisize-1; 24 /* ここから二分探索 */ 25 while(l<=r) { 26 /* ※ここを適切なプログラムで埋める */ 27 m = (l + r)/2; 28 if(strcmp(ekiname, ekidata[m]->name) == 0) { 29 //num[count++] = m; 30 for(i=m-20; i<=m+20; i++) { 31 if(strcmp(ekiname, ekidata[i]->name) == 0) { 32 printf("count = %d\n",count); 33 num[count++] = i; 34 } 35 } 36 printf("count = %d\n",count); 37 break; 38 } else if(strcmp(ekiname, ekidata[m]->name) < 0) { 39 r = m; 40 m = (l+r)/2; 41 } else { 42 l = m; 43 m =(l+r)/2; 44 } 45 } 46 return 0; 47}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答4

0

num[10]の配列数にご注目。
あきらか10個では足りないな。とりあえず256個ぐらい確保しとき。

投稿2019/01/31 07:31

stdio

総合スコア3307

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

apeirogon0813

2019/01/31 07:36

おっしゃるとおりでした。 ありがとうございます。
guest

0

num[10]で宣言された(num[0]num[9]までしか使えない)のに、num[10]以降に書き込んでしまったのが原因と思われます。

このような場合、何が起きても文句は言えません(正式には「未定義の動作」と呼ばれます)。

投稿2019/01/31 07:28

maisumakun

総合スコア145183

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

apeirogon0813

2019/01/31 07:36

はい、こういうときは他の変数も見ることを学びました。 ありがとうございます
guest

0

ベストアンサー

配列の添え字オーバーで、他の変数の値を破壊しているのでしょうね。

投稿2019/01/31 07:26

otn

総合スコア84499

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

apeirogon0813

2019/01/31 07:34

num[10]を変更したら無事に動作しました。 ありがとうございます
guest

0

ざっと見てcountに関する処理は問題ないように見えます。
しかしnum[count++] = i;にてcountが10以上でnum配列の範囲外に書き込みを行っています。
そのためint num[10], count = 0;で定義されたcount変数の領域まで書き込まれ、正しく動作していないと思われます。

投稿2019/01/31 07:37

can110

総合スコア38256

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問