08【C语言 & 趣味算法】再识:冒泡排序(问题分析、算法设计与分析、程序流程图以及完整代码)

简介: 08【C语言 & 趣味算法】再识:冒泡排序(问题分析、算法设计与分析、程序流程图以及完整代码)

一、前情回顾



07【C语言&趣味算法】最佳存款方案(采用从后往前递推解决)

06【c语言&趣味算法】牛顿迭代法求方程根(可回看)

05【C语言&趣味算法】经典:兔子产子问题(即:Fibonacci数列)

04【C语言&趣味算法】“抓交通肇事犯"问题。算法改进:设置"标识变量”,有效减少循环次数。

03【C语言&趣味算法】(值得品味的一道题)打鱼还是晒网?结构体的简单应用。函数的应用。判断闰年的应用。求指定日期距1990年1月1日的天数。

02【C语言&趣味算法】借书方案问题:小明有5本新书,要借给A、B、C三位小朋友,若每人每次只能借1本,则可以有多少种不同的借法?

01【C语言&趣味算法】百钱百鸡问题(问题简单,非初学者请忽略叭)。请注意算法的设计(程序的框架),程序流程图的绘制,算法的优化。


二、New Problem:冒泡排序(bubble sort)



在此之前,曾经是记录过冒泡排序的。比起记录过的那个例子,这里对冒泡排序进行了更为细致的分析。


2.1问题描述

0f76fbddb3d8471382b45a2a074e90b3.jpg

2.2Analysis of the problem(问题分析)、算法思想


e63c1057c8924f599a7cac3f7aad7aeb.jpg


2.3 Algorithm design(算法设计)


4e93f6f1831144cd8055c8fcef17a380.jpg

更为细致地分析一下:

f8dec1d442764f5ba4751fad3985bf8e.jpg4d93f69544f14240b586eaa95c9e1d26.jpg



2.4程序流程图,完整code 以及输出


首先是程序流程图,


f58f29c9966b4491a21362420fb56001.jpg


完整code如下,

这里以输入10个整数为例,定义N为10,如果想输入更多整数,那么同样可以把N定义为更大的整数,例如100。


// 趣味08:最佳存款方案 
#include<stdio.h>
#define N 10    /*因数组的大小不确定,所以采用宏定义的方式,数组大小改变时只需改变N对应的值不需要改动程序*/
int main()
{
int i,j,a[N],t,count=0;
  printf("请为数组元素赋初值:\n");
  for(i=0;i<N;i++)
  scanf("%d",&a[i]);
for(i=1;i<=N-1;i++)           /*控制比较的轮数*/
    for(j=0;j<N-i;j++)        /*控制每轮比较的次数*/
  if(a[j]>a[j+1])         /*数组相邻两个元素进行交换*/
{
  t=a[j];
  a[j]=a[j+1];
  a[j+1]=t;
}   
   printf("经过交换后的数组元素为:\n");
   for(i=0;i<N;i++)
   {   
  count++; 
      printf("%d  ",a[i]);
      if(count%5==0)        /*控制每行输出5个数*/
      printf("\n"); 
   }   
   printf("\n");
}


测试输出为:


626c797020bc4279aa27bd4806e2c7b6.jpg31b447331aa344ecbd75cfe2cb137cfd.jpg


2.5附:Question expansion(问题拓展): Select Sort(选择排序)

8d6aa09724b346d1ac4bf554dd3d77c7.jpg


相关文章
|
7天前
|
C语言
第一章 C语言知识点(程序)
第一章 C语言知识点(程序)
16 0
|
23小时前
|
算法 C语言 人工智能
|
1天前
|
机器学习/深度学习 算法 API
【Paddle】PCA线性代数基础 + 领域应用:人脸识别算法(1.1w字超详细:附公式、代码)
【Paddle】PCA线性代数基础 + 领域应用:人脸识别算法(1.1w字超详细:附公式、代码)
6 0
|
1天前
|
人工智能 算法 C语言
【C语言】求最小新整数(贪心算法)
【C语言】求最小新整数(贪心算法)
5 1
|
3天前
|
算法 C语言
C语言易混淆、简单算法、结构体题目练习、常见关键字总结-2
C语言易混淆、简单算法、结构体题目练习、常见关键字总结
|
3天前
|
算法 编译器 API
C语言易混淆、简单算法、结构体题目练习、常见关键字总结-1
C语言易混淆、简单算法、结构体题目练习、常见关键字总结
|
5天前
|
算法 关系型数据库 C语言
卡尔曼滤波简介+ 算法实现代码(转)
卡尔曼滤波简介+ 算法实现代码(转)
17 4
|
6天前
|
存储 自然语言处理 编译器
“ Hello world ”中的秘密之【C语言程序编译和链接】
作为C语言最经典的代码,大家都可以轻易写出。但是代码的运行过程却很少有人清楚,接下来我将介绍代码运行的奥秘。
15 0
|
6天前
|
运维 算法
基于改进遗传算法的配电网故障定位(matlab代码)
基于改进遗传算法的配电网故障定位(matlab代码)
|
6天前
|
算法 调度
基于多目标粒子群算法冷热电联供综合能源系统运行优化(matlab代码)
基于多目标粒子群算法冷热电联供综合能源系统运行优化(matlab代码)