前提
C言語でバブルソートを実装していますがエラーが出てうまくいきません
実現したいこと
バブルソートの実装
セグメンテーション違反がなぜ出るのか
セグメンテーション違反が出た際にどのようにしてコードの間違いを見つければいいのか
発生している問題・エラーメッセージ
oamke@DESKTOP-3PLG0UV ~/aizu/project1/ald1 $ gcc babblesort.c oamke@DESKTOP-3PLG0UV ~/aizu/project1/ald1 $ ./a.exe 5 5 3 2 4 1 Segmentation fault
該当のソースコード
C
1#include <stdio.h> 2 3int bubblesort(int a[], int n){ 4 int flag = 1; 5 int i=0; 6 int j, tmp; 7 int counter=0; 8 while(flag=1){ 9 flag=0; 10 for(j=n-1;j>i;j--){ 11 if(a[j]<a[j-1]){ 12 tmp=a[j]; a[j]=a[j-1]; a[j-1]=tmp; 13 flag=1; 14 counter++; 15 } 16 } 17 i++; 18 } 19 for(j=0; j<n; j++){ 20 printf("%d ", a[j]); 21 } 22 printf("\n"); 23 printf("%d\n", counter); 24} 25 26int main(){ 27 int a[101], n, i; 28 scanf("%d", &n); 29 for(i=0; i<n; i++){ 30 scanf("%d", &a[i]); 31 } 32 bubblesort(a, n); 33 return 0; 34}
試したこと
はじめはプログラムが終了しなかったため、for文でjをn-1から1まで動かしていたがiを設定しiまでにすることで計算量を減らした
質問のソースは、実行が終了しないコードであり、Segmentation fault にはならないと思います。
Segmentation fault になるコードを提示してください。
回答1件
あなたの回答
tips
プレビュー