【发布时间】:2013-07-02 11:50:14
【问题描述】:
这是其中一个程序,其中一组数字按升序排序,方法是在数组的左点和结尾之间的范围内找到最大的数字,然后将该元素移动到其正确的索引位置切换元素。我的问题是它不是按升序排列的,因为中间的数字没有排序,我想知道如何在程序中使用它。 这是我目前的代码:
#include <stdio.h> /* Library inclusions */
#include "genlib.h"
#include "simpio.h"
#define size 7 /* Constants */
void sortArray (int numbers[]); /* prototypes */
int indexMax (int numbers[], int low, int high);
void swap (int numbers[], int loc, int loc1);
void getArray (int numbers[]);
void displayArray (int numbers[]);
main()
{
int numbers[size];
getArray(numbers);
sortArray(numbers );
displayArray (numbers);
getchar();
}
void getArray (int numbers[]) /*Function getArray*/
{
int i;
for (i=0; i<size; i++)
{
printf ("Enter an integer? ");
numbers[i]=GetInteger();
}
}
void displayArray (int numbers[]) /*Function displayArray*/
{
int i;
printf ("\n The sorted list is: \n");
for (i=0; i< size; i++)
{
printf ("%d\t", numbers[i]);
}
}
void sortArray (int numbers[]) /*Function sortArray*/
{
int i , maxInd;
for (i=0; i<size;i++)
{
maxInd = indexMax (numbers, i, size-1);
swap (numbers, size-1, maxInd);
}
}
int indexMax (int numbers[], int low, int high) /*Function indexMax*/
{
int i, maxInd;
maxInd=high;
for (i=low;i<=high;i++)
{
if (numbers[i]>numbers[maxInd])
{
maxInd =i;
}
}
return (maxInd);
}
void swap (int numbers[], int loc, int loc1) /*Function swap*/
{
int temp;
temp=numbers[loc];
numbers[loc]=numbers[loc1];
numbers[loc1]=temp;
}
非常感谢。 :)
【问题讨论】:
-
今天承诺:一旦您不是初学者,您将更改显示名称。
-
您是否尝试过在调试器中逐行单步执行代码,以帮助您查看可能出现的问题?用一个小数组来做,这样就不会花这么长时间。
标签: c arrays stdio selection-sort