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. 提交结果

相关推荐
Navigator_Z12 小时前
LeetCode //C - 1089. Duplicate Zeros
c语言·算法·leetcode
笨笨没好名字14 小时前
怎么看懂51单片机电路图与功能实现的C语言编写(2-7入门篇)
c语言·嵌入式硬件·51单片机
QiLinkOS17 小时前
《打破“用爱发电”:一种基于 Gitee 与时间戳的开源权益分配机制探索》
c语言·数据结构·c++·科技·算法·gitee·开源
社交怪人19 小时前
【范围判断】信息学奥赛一本通C语言解法(题号2052)
c语言
LONGZETECH20 小时前
软硬协同+故障注入:无人机仿真维修与操控仿真底层算法逻辑拆解
大数据·c语言·算法·3d·unity·无人机
zlinear数据采集卡21 小时前
SPI Flash存储电路深度解析:从芯片选型到ZLinear采集卡的实战设计
c语言·嵌入式硬件·自动化·硬件架构
羊羊一洋1 天前
GCC __attribute__ 完全指南:从入门到实战
c语言·stm32
zz34572981131 天前
C语言中字符串常量存储位置
c语言·开发语言·算法·青少年编程
noipp1 天前
推荐题目:洛谷 P16510 [GKS 2015 #C] gRanks
java·c语言·开发语言·c++·python·算法
程序喵大人1 天前
从内存/汇编角度看C与C++:指针、引用、对象的底层差异
c语言·汇编·c++·指针·引用·对象