我必须根据第二列对排名和名称(用作字符串)的2D数组进行排序。我试图按字母顺序对它进行排序,但我似乎无法做到正确。我还是多维数组的新手,所以我还是很困惑。我正在使用Bubble Sort
,它正在对名称进行排序,但顺序不正确。
这是我正在尝试排序的数组:
const int ROWS=6;
const int COLS=2;
string names [ROWS][COLS] = { "1", "Jacob",
"2", "Michael",
"3", "Joshua",
"4", "Matthew",
"5", "Ethan",
"6", "Andrew"};
这就是我得到的:
2 Michael
4 Matthew
3 Joshua
1 Jacob
6 Andrew
5 Ethan
这是我正在使用的排序函数:
void sort (string names [][COLS], int size)
{
int i,j; // i = rows
string hold1, hold2;
for (i=0; i < size-1; i++)
{
for (j=0; j < size; j++)
{
if (names [i][1] > names [j][1]) //names = col 1 , rank = col 0
{
hold1 = names [i][1];
hold2 = names [i][0];
names [i][1] = names [j][1];
names [i][0] = names [j][0];
names [j][1] = hold1;
names [j][0] = hold2;
}
}
}
}
提前致谢。
答案 0 :(得分:2)
你实际上来回交换元素。您需要确保在进行冒泡排序时,您只是将元素与以后的元素进行比较。那就是:
for (i=0; i < size-1; i++)
{
for (j=i+1; j < size; j++)
^^^^
{
// same as before
}
}
请注意,我们可以利用标准实用程序使此代码更容易理解。我写的//same as before
行...你在那里做的只是交换names[i]
和names[j]
,我们可以拼写:
std::swap(names[i], names[j]);
这更容易理解,更不容易出错。
答案 1 :(得分:0)
你搞错了泡泡。试试这个:
for (i=0; i<size; i++)
{
for (j=0; j < size-1; j++)
{
if (names [j][1] > names [j+1][1])
{
hold1 = names [j][1];
hold2 = names [j][0];
names [j][1] = names [j+1][1];
names [j][0] = names [j+1][0];
names [j+1][1] = hold1;
names [j+1][0] = hold2;
}
}
}