7-27 冒泡法排序

题目链接:7-27 冒泡法排序

一. 题目

1. 题目

2. 输入输出格式

3. 输入输出样例

4. 限制

二、代码

1. 代码实现

c 复制代码
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>

// 数字初始化函数
int *arrayGet(int len) {
    int *array;
    array = malloc(len * sizeof(int));
    for (int i = 0; i < len; i++) {
        if (!scanf("%d", &array[i])) {
            return 0;
        }
    }
    return array;
}

// 冒泡排序
int *arraySort(int *array, int len, int time) {
    int tempNum;
    for (int tempTime = 0; tempTime < time; tempTime++) {
        for (int i = 0; i < len - 1; i++) {
            if (array[i] > array[i+1]) {
                tempNum     = array[i];
                array[i]    = array[i+1];
                array[i+1]  = tempNum;
            }
        }
        len --; // 下次排序的比较次数减1
    }
    return array;
}

// 打印函数
void arrayPrint(int *array, int len) {
    bool printOnce = false;
    while (len) {
        if (printOnce) {
            printf (" %d", *array);
        } else {
            printf ("%d", *array);
            printOnce = true;
        }
        array++;
        len--;
    }
}

int main(void) {
    int len, time;
    int *array;

    if (scanf("%d %d", &len, &time) != 2) {
        return -1;
    }
    array = arrayGet(len);
    if (!array) {
        return -1;
    }
    array = arraySort(array, len, time);
    arrayPrint(array, len);
    free(array);

    return 0;
}

2. 提交结果

相关推荐
丑小鸭是白天鹅2 小时前
嵌入式C语言学习笔记之枚举、联合体
c语言·笔记·学习
GUET_一路向前3 小时前
【C语言防御性编程】if条件常量在前,变量在后
c语言·开发语言·if-else·防御性编程
pusue_the_sun4 小时前
数据结构——栈和队列oj练习
c语言·数据结构·算法··队列
Dontla5 小时前
Makefile介绍(Makefile教程)(C/C++编译构建、自动化构建工具)
c语言·c++·自动化
奶黄小甜包5 小时前
C语言零基础第18讲:自定义类型—结构体
c语言·数据结构·笔记·学习
一支闲人5 小时前
C语言相关简单数据结构:双向链表
c语言·数据结构·链表·基础知识·适用于新手小白
John.Lewis6 小时前
数据结构初阶(19)外排序·文件归并排序的实现
c语言·数据结构·排序算法
John.Lewis6 小时前
数据结构初阶(16)排序算法——归并排序
c语言·数据结构·排序算法
wearegogog1237 小时前
C语言中的输入输出函数:构建程序交互的基石
c语言·开发语言·交互
艾莉丝努力练剑19 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法