【发布时间】:2018-09-26 05:12:06
【问题描述】:
所以我正在制作一个选择排序程序,其中我必须输入两个值:一个用于数组中使用的数字,另一个用于随机数生成器的种子。我只是对如何调整使用的数字有点困惑,因为我们最多可以放入 15 个元素。数组目前有 8 个。每个元素应该是 20 到 40 之间的数字。
#include <iostream>
using namespace std;
int selectionSort(int[], int);
int selectionSort(int numbers[], int numbersSize) {
int i = 0;
int j = 0;
int indexSmallest = 0;
int temp = 0; // Temporary variable for swap
for (i = 0; i < numbersSize - 1; ++i) {
// Find index of smallest remaining element
indexSmallest = i;
for (j = i + 1; j < numbersSize; ++j) {
if (numbers[j] < numbers[indexSmallest]) {
indexSmallest = j;
}
}
// Swap numbers[i] and numbers[indexSmallest]
temp = numbers[i];
numbers[i] = numbers[indexSmallest];
numbers[indexSmallest] = temp;
}
return indexSmallest;
}
int main() {
int numbers[] = {10, 2, 78, 4, 45, 32, 7, 11, 0, 0, 0, 0, 0, 0, 0};
const int NUMBERS_SIZE = 15;
int i = 0;
int nums = 0;
int seed = 0;
cin >> nums;
cin >> seed;
srand(seed);
for (int i = 0; i < nums; i++) {
numbers[i] = (rand() % 20) + 20;
}
cout << "UNSORTED: ";
for (i = 0; i < nums; ++i) {
cout << numbers[i] << " ";
}
cout << endl;
selectionSort(numbers, nums);
cout << "SORTED: ";
for (i = 0; i < nums; ++i) {
cout << numbers[i] << " ";
}
cout << endl;
system("pause");
return 0;
}
唯一的问题是生成的随机数是错误的数字。例如,当我输入“10 100”(数组中使用的数字为 10,种子为 100)时,它会输出
未分类:25 36 35 24 24 34 38 22 29 29
排序:22 24 24 25 29 29 34 35 36 38
什么时候输出
未分类:28 28 34 37 36 27 33 36 36 39
排序:27 28 28 33 34 36 36 36 37 39
我不确定如何解决这个问题。
【问题讨论】:
-
为什么你认为 srand(100) 应该产生 28 作为第一个数字?我认为这取决于编译器。 stackoverflow.com/questions/3503825/…
-
随机值如何是对还是错?
标签: c++