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

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

新規登録して質問してみよう
ただいま回答率
85.35%
ソート

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

C++

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

Q&A

解決済

1回答

1221閲覧

c++ バブルソートについてです

_._._ami

総合スコア26

ソート

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

C++

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

0グッド

0クリップ

投稿2020/10/21 08:27

下記のコードのflagは何を意味していますか?
while(flag)の意味も分からないです.

入力した値をソートしているのは理解できました.
xが数字を入れ変えた回数というのも理解できました.

c++

1#include<iostream> 2using namespace std; 3 4int main(){ 5 int n,A[100]; 6 cin >> n; 7 for(int j=0;j<n;j++) cin >> A[j]; 8 9 int flag = 1; 10 int x =0; 11 while(flag){ 12 flag = 0; 13 for(int j=n-1;j>=0;j--){ 14 int v = A[j]; 15 if(A[j]<A[j-1]){ 16 int v = A[j]; 17 A[j] = A[j-1]; 18 A[j-1] = v; 19 flag = 1; 20 x++; 21 } 22 23 } 24 } 25 26 27 for(int j=0;j<n;j++){ 28 if(j==0) cout << A[j]; 29 else cout << " " << A[j]; 30 } 31 32 cout << endl; 33 cout << x << endl; 34 35}

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

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

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

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

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

guest

回答1

0

ベストアンサー

while(flag)の意味も分からないです.

flagの値が0でないならループ,です.
よって,

flagは何を意味していますか?

については,「ループの終了条件を制御している」と言えます.
whileループ内の最初にflag=0とされ,要素を交換した際にflag=1とされているので,
「forループ内で一度でも要素を交換したならば flagの値を1にする」ということ.
すなわち,全く要素を交換しなかったならばwhileループを抜けるということ.

投稿2020/10/21 08:53

fana

総合スコア11996

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

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

_._._ami

2020/10/21 12:13

なるほど、理解できました!とっても分かりやすくありがとうございました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問