wxcxoy
2015-12-27 16:19
采纳率: 100%
浏览 7.6k
已采纳

C语言,简单冒泡排序排10个整数,分别按照升序降序输出,请问怎么实现?

C语言,简单冒泡排序排10个整数,分别按照升序降序输出,请问怎么实现?

  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 收藏
  • 邀请回答

7条回答 默认 最新

  • threenewbee 2015-12-27 21:41
    已采纳
     void foo(int * data, int n, int desc)
    {
        for (int i = 0; i < n - 1; i++)
        {
            for (int j = 0; j < n - i; j++)
            {
    
                    if ((data[j + 1] < data[j] && desc) || (data[j + 1] > data[j] && !desc))
                    {
                        int t = data[j + 1];
                        data[j + 1] = data[j];
                        data[j] = t;
                    }
    
            }
        }
    }
    
    int main()
    {
        int data[] = { 3, 2, 3, 4, 1, 9, 5, 2, 6, 8 };
        for (int i = 0; i < 10; i++)
            printf("%d ", data[i]);
        printf("\n");
        foo(data, 10, 0);
        for (int i = 0; i < 10; i++)
            printf("%d ", data[i]);
        printf("\n");
        foo(data, 10, 1);
        for (int i = 0; i < 10; i++)
            printf("%d ", data[i]);
        printf("\n");
    }
    
    评论
    解决 2 无用
    打赏 举报
  • 查看更多回答(6条)

相关推荐 更多相似问题