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

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

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

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

C++

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

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

Q&A

解決済

3回答

543閲覧

beginメンバ関数を変える方法が知りたい。

langhtorn

総合スコア105

ソート

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

C++

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

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

0グッド

0クリップ

投稿2020/07/03 06:55

編集2020/07/03 06:56

###実現したいこと
実数値のデータの中から大きい順、小さい順にデータを並べるということをしたいです。選択ソートを使います。

###試したこと
最小値が分かりやすいようにit_minが表示されるようにしました。
###問題点
選択ソートは
data[0]と{data[0]~data[n-1]}の最小値を交換する。
data[1]と{data[1]data[n-1]}の最小値を交換する
...
というのをずっと続けていくものです。
auto it_min=std::min_element(data.begin(),data.end());の部分で最小値を求めるのですが、これでは毎回配列のdata[0]
[10]の最小値になってしまいます。data.begin()をdata[0],data[1]...というように変えることはできないのでしょうか。data.begin()はずっと不動でdata[0]しか見てくれないのでしょうか?
最大値の場合もそうです。。。
実行結果

データ数を入力してください: 10 実数値データを入力してください: 5 2 3 1 9 5 4 3 6 0 it_min=0 it_min=0 it_min=0 it_min=0 it_min=0 it_min=0 it_min=0 it_min=0 it_min=0 it_min=0 1番目に小さな値:2 2番目に小さな値:3 3番目に小さな値:1 4番目に小さな値:9 5番目に小さな値:5 5番目に大きな値:4 4番目に大きな値:9 3番目に大きな値:5 2番目に大きな値:2 1番目に大きな値:1

###コード

C++

1/*実数値のデータの中から大きい順、小さい順にデータを並べる*/ 2 3#include<iostream> 4#include<algorithm> 5#include<vector> 6#include<utility> 7 8int main() 9{ 10 int i; 11 int n; //データ数 12 std::cout<<"データ数を入力してください:\n"; 13 std::cin>>n; //10以上と仮定する 14 std::cout<<"実数値データを入力してください:\n"; 15 std::vector<double> data; 16 for(i=0;i<n;i++){ 17 int d; 18 std::cin>>d; 19 data.push_back(d); 20 } 21 22 //選択ソートの基本操作を5回繰り返す(最小値を求めて並べていく) 23 for(i=0;i<n;i++){ 24 auto it_min=std::min_element(data.begin(),data.end()); //最小値を指すイテレータ 25 std::cout<<"it_min="<<*it_min<<" "; 26 std::swap(data[i],*it_min); //二つの値の交換 27 } 28 29 std::cout<<"\n"; 30 //小さい順に表示 31 for(i=0;i<5;i++){ 32 std::cout<<i+1<<"番目に小さな値:"<<data[i]<<"\n"; 33 } 34 std::cout<<" \n"; 35 36 //上記の逆バージョン(最大値) 37 for(i=0;i<5;i++){ 38 auto it_max=std::max_element(data.begin(),data.end()); 39 std::swap(data[i],*it_max); 40 } 41 42 //大きい順に表示 43 for(i=5;i>0;i--){ 44 std::cout<<i<<"番目に大きな値:"<<data[i]<<"\n"; 45 } 46 47 return 0; 48}

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

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

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

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

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

guest

回答3

0

data.begin()はずっと不動でdata[0]しか見てくれないのでしょうか?

はい、そのとおりです。

投稿2020/07/03 06:58

maisumakun

総合スコア146018

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

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

langhtorn

2020/07/04 06:10

了解しました。回答ありがとうございます。
guest

0

完成したコードを貼っておきます。

C++

1/*実数値のデータの中から大きい順、小さい順にデータを並べる*/ 2 3#include<iostream> 4#include<algorithm> 5#include<vector> 6#include<utility> 7 8int main() 9{ 10 int i; 11 int n; //データ数 12 std::cout<<"データ数を入力してください:\n"; 13 std::cin>>n; //10以上と仮定する 14 std::cout<<"実数値データを入力してください:\n"; 15 std::vector<double> data; 16 for(i=0;i<n;i++){ 17 double d; 18 std::cin>>d; 19 data.push_back(d); 20 } 21 22 //選択ソートの基本操作を5回繰り返す(最小値を求めて並べていく) 23 auto first=data.begin(); 24 for(i=0;i<5;i++){ 25 auto it_min=std::min_element(first,data.end()); //最小値を指すイテレータ 26 //std::cout<<"it_min="<<*it_min<<" "; 27 std::swap(data[i],*it_min); //二つの値の交換 28 first++; 29 } 30 31 std::cout<<"\n"; 32 //小さい順に表示 33 for(i=0;i<5;i++){ 34 std::cout<<i+1<<"番目に小さな値:"<<data[i]<<"\n"; 35 } 36 std::cout<<" \n"; 37 38 //std::cout<<"最大値\n"; 39 40 //上記の逆バージョン(最大値)多分このやり方だと添え字0~9で小さい順に並べてる? 41 auto last=data.end(); 42 for(i=n-1;i>=n-5;i--){ 43 auto it_max=std::max_element(data.begin(),last); //最大値を指すイテレータ 44 //std::cout<<"it_max="<<*it_max<<" "; 45 std::swap(data[i],*it_max); //二つの値の交換 46 //std::cout<<"||swapした後のdata["<<i<<"]="<<data[i]<<"|| "; 47 last--; 48 } 49 //std::reverse(data.begin(),data.end()); //小さい順を大きい順にする 50 51 52 std::cout<<"\n"; 53 int j=5; //番目の表示 54 //大きい順に表示 55 for(i=n-5;i<=n-1;i++){ //5,6,7,8,9 56 std::cout<<j<<"番目に大きな値:"<<data[i]<<"\n"; 57 j--; 58 } 59 60 return 0; 61} 62 63/*実行結果 64データ数を入力してください: 6510 66実数値データを入力してください: 6735 2.5 5 9 3.3 1 0.5 25 4 100 68 691番目に小さな値:0.5 702番目に小さな値:1 713番目に小さな値:2.5 724番目に小さな値:3.3 735番目に小さな値:4 74 75 765番目に大きな値:5 774番目に大きな値:9 783番目に大きな値:25 792番目に大きな値:35 801番目に大きな値:100 81*/

投稿2020/07/04 06:12

langhtorn

総合スコア105

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

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

0

ベストアンサー

data.begin()をdata[0],data[1]...というように変えることはできないのでしょうか。

どってことないっスよ:

C++

1 ... 2 //選択ソートの基本操作を繰り返す(最小値を求めて並べていく) 3 auto first = data.begin(); 4 while ( first != data.end() ) { 5 auto it_min = std::min_element(first, data.end()); //最小値を指すイテレータ 6 std::cout << "it_min=" << *it_min << " "; 7 std::iter_swap(first, it_min); //二つの値の交換 8 ++first; // 次いこか次 9 } 10 ...

投稿2020/07/03 07:03

編集2020/07/03 07:41
episteme

総合スコア16612

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

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

langhtorn

2020/07/04 06:10

参考にさせていただきました。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問