题目描述:
给你n个整数,请按从大到小的顺序输出其中前m大的数。
输入:
每组测试数据有两行,第一行有两个数n,m(0

输出:
对每组测试数据按从大到小的顺序输出前m大的数。
样例输入:
5 33 -35 92 213 -644

样例输出:
213 92 3

解法1

解法一
#include 
#include
#include
#include
#define N 1000000
using namespace std;
int a[N];
int main()
{
    int n, m, i, flag = 0;
    while (scanf_s("%d%d", &n, &m) != EOF) {
        for (i = 0;i1;i--) {
            printf(" %d", a[flag]);
            flag--;
        }
        cout 

解法2

解法二
#include 
#define OFFSET 500000 //偏移量,用于补偿实际数字与数组下标之间偏移
int Hash[1000001]; //偏移量,用于补偿实际数字与数组下标之间偏移
int main() {
    int n, m;
    while (scanf("%d%d", &n, &m) != EOF) {
        for (int i = -500000;i = -500000;i--) {  //输出前m个数 
            if (Hash[i + OFFSET] == 1) { //若该数字在输入中出现 
                printf("%d", i); //输出该数字
                m--; //输出一个数字后,m减一,直至m变为0 
                if (m != 0) printf(" "); //注意格式,若m个数未被输出完毕,在输出的 数字后紧跟一个空格
                else {
                    printf("\n"); //若m个数字已经被输出完毕,则在输出的数字后面紧跟 一个换行, 并跳出遍历循环
                        break;
                }
            }
        }
    }
    return 0;
}

解法3

解法三
#include
#define N 1000000
int array[N];

void quick_sort(int s[], int l, int r)
{
    int i, j, x;
    if (l  x)
                j--; /* 从右向左找第一个小于x的数 */
            if (i = n-temp;j--) {
            printf_s("%d", array[j]);
            m--;        
            if (m != 0)
            printf(" ");
            else {
            printf("\n");
            break;
        }        
        }


    }
    return 0;
}

总结:解法三是我自己写的,一次快速排序+反向的for循环。

过程中遇到的错误

输出格式不正确。
解决办法:每次输出数字后m-1,m等于0的时候跳出循环即可。

本博客所有内容采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可

转载文章请注明:排序练习 - https://blog.i-ll.cc/archives/99

分类: Coding

Vectors

Vectors

不知所措,才是人生。

发表评论

电子邮件地址不会被公开。 必填项已用*标注

我不是机器人*