fork download
  1. #include<iostream>
  2. #include<array>
  3.  
  4. const int items = 25;
  5.  
  6. int selection=0; //位置が確定している要素は0
  7. int s=0; //サンプルを配列の0番目にする
  8. int l=1; //レフトポインタを配列の1番目にする
  9. int r=items-1; //itemsは配列の要素数(25に設定) ライトポインタは、配列の一番最後―要素数-1番目にする
  10.  
  11. std::array<bool, items> checker;
  12. std::array<int, items> number = {1,2,3,4,5,6,7,18,9,10,11,12,13,14,15,16,17,8,19,20,21,22,23,24,25};
  13.  
  14. void Sort();
  15.  
  16. int main()
  17. {
  18. checker.fill(false);
  19. while (selection < items) {
  20. Sort();
  21. std::cout << "l:" << l << " r:" << r << " s:" << s << std::endl;
  22. }
  23. for (int i = 0; i < items; i++) {
  24. std::cout << number[i] << std::endl;
  25. }
  26. return 0;
  27. }
  28.  
  29. void Sort(void)
  30. {
  31. while(number[l]<number[s]){ //サンプルの値よりレフトポインタの値が小さいなら
  32. if(l!=r){ //もしライトポインタ場所が一致していないなら
  33. l++; //レフトポインタを右へ移動する
  34. }
  35. else{
  36. break; //もしぶつかってしまったら抜ける
  37. }
  38. }
  39. while(number[r]>number[s]){ //サンプルの値よりライトポインタの値が大きいなら
  40. if(r!=l){ //もしライトポインタと場所が一致していないなら
  41. r--; //ライトポインタを左へ移動する
  42. }
  43. else{
  44. break; //もしぶつかってしまったら抜ける
  45. }
  46. }
  47. if(l!=r){ //もしレフトポインタの場所とライトポインタの場所が一致していなかったら
  48. int tmp=number[l]; //レフトポインタの値とライトポインタの値を入れ替える
  49. number[l]=number[r];
  50. number[r]=tmp;
  51. }
  52. else{ //もし一致していたら
  53. if(number[s]<number[l]){ //大小関係を比較して、サンプルの値の方が小さいなら
  54. int tmp=number[s]; //サンプルの値と一致していた前の値とを入れ替える
  55. number[s]=number[l-1];
  56. number[l-1]=tmp;
  57. checker[l-1]=true;//サンプルの値を入れたところは場所確定
  58. selection++; //確定した場所が1つ増えた
  59. }
  60. else{ //もしサンプルの値の方が大きいなら
  61. int tmp=number[s]; //サンプルの値と一致したところの値とを入れ替える
  62. number[s]=number[l];
  63. number[l]=tmp;
  64. checker[l]=true;//サンプルの値を入れたところは場所確定
  65. selection++; //確定した場所が1つ増えた
  66. }
  67. bool check=true; //サンプルの場所を設定しているかどうかを記憶
  68. if(s==l || s==l-1){ //サンプルの場所とライトポインタの場所が一致しているか、サンプルの場所がライトポインタの手前なら
  69. check=false; //これから設定しに行く
  70. for(int n=s+1;n<items;n++){
  71. if(checker[n]==false){ //まだ場所が確定していない場所があったら
  72. s=n; //サンプルの場所をそこに設定
  73. check=true; //サンプルの場所を設定
  74. break;
  75. }
  76. }
  77. }
  78. if(check==true){ //サンプルの場所が設定できていれば
  79. if(checker[s+1]==false){ //サンプルのとなりが空いていれば
  80. l=s+1; //レフトポインタをサンプルのとなりにする
  81. }
  82. else{ //空いていなければ
  83. l=s; //レフトポインタをサンプルのところにする
  84. }
  85. for(int n=items-1;n>=l;n--){ //ライトポインタの場所を設定しに行く
  86. if(checker[n]==false){ //配列の最後から確定していないところが見つかり次第
  87. r=n; //ライトポインタをそこにする
  88. break;
  89. }
  90. }
  91. }
  92. }
  93. }
Runtime error #stdin #stdout 0s 2884KB
stdin
Standard input is empty
stdout
l:2 r:24 s:1
l:3 r:24 s:2
l:4 r:24 s:3
l:5 r:24 s:4
l:6 r:24 s:5
l:7 r:24 s:6
l:8 r:24 s:7
l:8 r:24 s:7
l:9 r:24 s:8
l:10 r:24 s:9
l:11 r:24 s:10
l:12 r:24 s:11
l:13 r:24 s:12
l:14 r:24 s:13
l:15 r:24 s:14
l:16 r:24 s:15
l:16 r:24 s:16
l:19 r:24 s:18
l:20 r:24 s:19
l:21 r:24 s:20
l:22 r:24 s:21
l:23 r:24 s:22
l:24 r:24 s:23
l:25 r:24 s:24
l:24 r:18 s:18
l:3b r:18 s:18