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

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

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

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

Q&A

解決済

1回答

454閲覧

C言語でのバブルソート

cgen

総合スコア17

C

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

0グッド

0クリップ

投稿2022/08/10 16:00

前提

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までにすることで計算量を減らした

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

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

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

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

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

kazuma-s

2022/08/10 17:05

質問のソースは、実行が終了しないコードであり、Segmentation fault にはならないと思います。 Segmentation fault になるコードを提示してください。
guest

回答1

0

ベストアンサー

while(flag=1){flag=1flag == 1 または flag にしてください。
なぜ、これでいいのかコメントをお願いします。

投稿2022/08/10 16:19

kazuma-s

総合スコア8224

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

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

cgen

2022/08/12 05:55

できました!ありがとうございます flag=1だとflagに1を代入してしまうからですね
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問