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

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

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

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

ソート

複数のデータを、順序性に従って並べ替えること。 データ処理を行う際に頻繁に用いられ、多くのアルゴリズムが存在します。速度、容量、複雑さなどに違いがあり、高速性に特化したものにクイックソートがあります。

例外

例外(exception)とは、プログラムの処理実行中に発生する、通常の処理の続行を妨げる特殊な事象のことを呼びます。この「例外」が発生した場合に、現在の処理を中断し、変わりに別の処理を実行させる事を「例外処理」と呼びます。

Q&A

解決済

1回答

767閲覧

選択ソートを複数回繰り返すと例外エラーになってしまう

misemi

総合スコア8

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

ソート

複数のデータを、順序性に従って並べ替えること。 データ処理を行う際に頻繁に用いられ、多くのアルゴリズムが存在します。速度、容量、複雑さなどに違いがあり、高速性に特化したものにクイックソートがあります。

例外

例外(exception)とは、プログラムの処理実行中に発生する、通常の処理の続行を妨げる特殊な事象のことを呼びます。この「例外」が発生した場合に、現在の処理を中断し、変わりに別の処理を実行させる事を「例外処理」と呼びます。

0グッド

0クリップ

投稿2020/07/04 18:32

編集2020/07/04 18:33

前提・実現したいこと

選択ソートの実行時間を計測するために、ソートを複数回繰り返した後、その合計実行時間を実行回数で割って出力するプログラムを書きたいです。一定以下の実行回数では実現できています。

実行環境はWindows10, VSCodeです。

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

大きさがSIZEの配列の全要素に乱数を入れてそれを選択ソートする、というのをCOUNT回繰り返すプログラムを書いたのですが、COUNTが1000程度より大きくなると、selectionSort(a)の行で例外エラーを吐いて止まってしまいます。
COUNTが1000以下だと普通に動作します。

例外が発生すると、VSCodeのデバッグ欄の「CALL STACK」->「Thread #1」の欄に「PAUSED ON EXCEPTION」と表示されます。コールスタックは以下のような感じです。エラーメッセージは表示されませんでした。

__mingwthr_run_key_dtors.part.0 (Unknown Source:0) __mingw_TLScallback (Unknown Source:0) __dyn_tls_dtor (Unknown Source:0) ntdll.dll!ntdll!RtlActivateActivationContextUnsafeFast (Unknown Source:0) ntdll.dll!ntdll!RtlActivateActivationContextUnsafeFast (Unknown Source:0) ntdll.dll!ntdll!LdrShutdownProcess (Unknown Source:0) ntdll.dll!ntdll!RtlExitUserProcess (Unknown Source:0) kernel32.dll!KERNEL32!FatalExit (Unknown Source:0) msvcrt.dll!msvcrt!_exit (Unknown Source:0) msvcrt.dll!msvcrt!_initterm_e (Unknown Source:0) __tmainCRTStartup (Unknown Source:0) mainCRTStartup (Unknown Source:0)

該当のソースコード

c

1#include <stdio.h> 2#include <stdlib.h> 3#include <windows.h> 4#define SIZE 100 5#define COUNT 1100 6 7int main() { 8 long start_time, end_time; 9 double process_time; 10 srand(GetTickCount()); 11 static int a[SIZE]; 12 int i, j; 13 14 start_time = GetTickCount(); 15 for(i = 0; i < COUNT; i++) { 16 for(j = 0; j < SIZE; j++) { 17 a[i] = rand(); 18 } 19 selectionSort(a); 20 } 21 end_time = GetTickCount(); 22 23 printf("%ld, %ld\n", start_time, end_time); 24 process_time = (double)(end_time - start_time) / 1000.0 / COUNT; 25 printf("実行時間: %.6f\n", process_time); 26} 27 28void selectionSort(int *a) {; 29 int min, i, j, tmp, min_index; 30 for(i = 0; i < SIZE; i++) { 31 min = a[i]; 32 min_index = i; 33 for(j = i + 1; j < SIZE; j++) { 34 if(a[j] < a[min_index]) { 35 min = a[j]; 36 min_index = j; 37 } 38 } 39 tmp = a[i]; 40 a[i] = a[min_index]; 41 a[min_index] = tmp; 42 } 43}

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

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

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

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

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

guest

回答1

0

ベストアンサー

main()で確保しているaの要素数は100にもかかわらず、100以降の要素に範囲外アクセスしています。

C

1 for (i = 0; i < COUNT; i++) { 2 for (j = 0; j < SIZE; j++) { 3 a[i] = rand(); // <-ここで100以降の要素に範囲外アクセス 4 } 5 selectionSort(a); 6 }

a[i] = rand();a[j] = rand();では?

投稿2020/07/04 18:50

編集2020/07/04 18:54
SHOMI

総合スコア4079

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

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

misemi

2020/07/04 19:05

完全に打ち間違えてました。ありがとうございます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問