2020

绝对值从大到小排序

冒泡排序

 

#include <stdio.h>
#include <math.h>

int main()
{
	int n;
	
	while (scanf_s("%d", &n) && n)
	{
		int i, j, t, s[101] = { 0 };
		for (i = 0; i < n; i++)
			scanf_s("%d", &s[i]);
		for (i = 0; i < n; i++)
		{
			//冒泡排序
			for (j = 0; j < n - 1 - i; j++)
			{
				if (abs(s[j]) < abs(s[j + 1]))
					t = s[j + 1]; s[j + 1] = s[j]; s[j] = t;
			}
		}
		for (i = 0; i < n; i++)
			printf("%d%c",s[i],(i < n -1 ? ' ':'\n'));

	}
	return 0;
}

  

参考答案

#include <math.h>
#include <stdio.h>
#include <stdlib.h>

int cmp(const int *a, const int *b)
{
    return abs(*b) - abs(*a);
}

int main(void)
{
    int n, i, x[101];
    
    while (scanf("%d", &n), n)
    {
        for (i = 0 ; i < n ; i++)
            scanf("%d", x + i);
        qsort(x, n, sizeof(int), cmp);
        for (i = 0 ; i < n ; i++)
            printf("%d%c", x[i], (i != n - 1 ? ' ' : '\n'));
    }

    return 0;
}

  

 

posted @ 2016-03-30 14:03  ailx10  阅读(141)  评论(0编辑  收藏  举报