zoukankan      html  css  js  c++  java
  • c语言----- 冒泡排序 for while do-while 递归练习

    1. 冒泡排序简介(默认从小到大排序)

     核心思想:只比较相邻的两个元素,如果满足条件就交换

         5 8 2 1 6 9 4 3 7 0

    目标:0 1 2 3 4 5 6 7 8 9
      第一次排序:
      5 < 8 不交换

      5 8 2 1 6 9 4 3 7 0

              8 >2 满足条件 交换....
      5 2 8 1 6 9 4 3 7 0
      5 2 1 8 6 9 4 3 7 0
      5 2 1 6 8 9 4 3 7 0
      5 2 1 6 8 9 4 3 7 0
      5 2 1 6 8 4 9 3 7 0
      5 2 1 6 8 4 3 9 7 0
      5 2 1 6 8 4 3 7 9 0
      5 2 1 6 8 4 3 7 0 9

      
      
      下一次交换
      2 5 1 6 8 4 3 7 0 9
      2 1 5 6 8 4 3 7 0 9
      2 1 5 6 8 4 3 7 0 9
      2 1 5 6 8 4 3 7 0 9
      2 1 5 6 4 8 3 7 0 9
      2 1 5 6 4 3 8 7 0 9
      2 1 5 6 4 3 7 8 0 9
      2 1 5 6 4 3 7 0 8 9
      

      下一次交换
      1 2 5 6 4 3 7 0 8 9
      1 2 5 6 4 3 7 0 8 9
      1 2 5 6 4 3 7 0 8 9
      1 2 5 4 6 3 7 0 8 9
      1 2 5 4 3 6 7 0 8 9
      1 2 5 4 3 6 7 0 8 9
      1 2 5 4 3 6 0 7 8 9
      

      下一次交换
      1 2 5 4 3 6 0 7 8 9
      1 2 5 4 3 6 0 7 8 9
      1 2 4 5 3 6 0 7 8 9
      1 2 4 3 5 6 0 7 8 9
      1 2 4 3 5 6 0 7 8 9
      1 2 4 3 5 0 6 7 8 9
      

      下一次交换
      1 2 4 3 5 0 6 7 8 9
      1 2 4 3 5 0 6 7 8 9
      1 2 3 4 5 0 6 7 8 9
      1 2 3 4 5 0 6 7 8 9
      1 2 3 4 0 5 6 7 8 9
      

       下一次交换
      1 2 3 4 0 5 6 7 8 9
      1 2 3 4 0 5 6 7 8 9
      1 2 3 4 0 5 6 7 8 9
      1 2 3 0 4 5 6 7 8 9
      

      下一次交换
      1 2 3 0 4 5 6 7 8 9
      1 2 3 0 4 5 6 7 8 9
      1 2 0 3 4 5 6 7 8 9
      

      下一次交换
      1 2 0 3 4 5 6 7 8 9
      1 0 2 3 4 5 6 7 8 9 

      下一次交换
      0 1 2 3 4 5 6 7 8 9

    2. 总共进行了 n-1次大的交换(n个元素   只有1个元素不需要排序)

      5 2 1 6 8 4 3 7 0 9   //这次交换 一共变化了9次
      2 1 5 6 4 3 7 0 8 9  // 8次
      1 2 5 4 3 6 0 7 8 9
      1 2 4 3 5 0 6 7 8 9
      1 2 3 4 0 5 6 7 8 9
      1 2 3 0 4 5 6 7 8 9
      1 2 0 3 4 5 6 7 8 9
      1 0 2 3 4 5 6 7 8 9
      0 1 2 3 4 5 6 7 8 9
      每一次小交换是9 8 7 6 5 4 3 2 1 次交换,也就是说

    for(int i = 0;i < N-1;i++){
    
      for(int j = 0;j < N-1-i;i++){
              交换 ...
        }
    }
        

    3. 实战 for while do-while 递归

    #include<stdio.h>
    #include<stdlib.h>
    #define N 10
    void print(int *a){
        for (int i = 0; i < N; i++)
        {
            printf("%d ",*(a+i));
        }
        printf("
    ");
    }
    void maopao_for(int *a){
        for (int i = 0; i < N - 1; i++) {
            for (int j = 0; j < N - 1 - i; j++) {
                if (a[j] > a[j + 1]) {
                    int temp = a[j];
                    a[j] = a[j + 1];
                    a[j + 1] = temp;
                }
            }
            print(a);
        }
    }
    void maopao_while(int *a) {
        int i = 0;
        while (i < N - 1)
        {
            int j = 0;
            while (j < N - 1 - i)
            {
                if (a[j] > a[j + 1]) {
                    int temp = a[j];
                    a[j] = a[j + 1];
                    a[j + 1] = temp;
                }
                j++;
            }
            print(a);
            i++;
        }
    }
    void maopao_do_while(int *a) {
        int i = 0;
        do{
            int j = 0;
            do{
                if (a[j] > a[j + 1]) {
                    int temp = a[j];
                    a[j] = a[j + 1];
                    a[j + 1] = temp;
                }
                j++;
            } while (j < N - 1 - i);
            print(a);
            i++;
        } while (i < N - 1);
    }
    // 递归可以减少一次循环
    void maopao_digui(int *a,int count) {
        if(count>=N) return ;
        for (int j = 0; j < N - 1 - count; j++) {
            if (a[j] > a[j + 1]) {
                int temp = a[j];
                a[j] = a[j + 1];
                a[j + 1] = temp;
            }
        }//printf("下一次交换
    
    
    ");
            print(a);
        maopao_digui(a,count+1);
    }
    int main(){
        int a[N] = {5,8,2,1,6,9,4,3,7,0};
        printf("排序前:
    ");
        print(a);
        printf("排序中:
    ");
        maopao_digui(a,0);
        printf("排序后:
    ");
        print(a);
        return 0;
    }
  • 相关阅读:
    视图中使用select a.* 更改了表a的结构 导致读取字段值时发生错位
    sql 压缩文件(rar或zip)
    单击触发jquery.autocomplete的两种方法
    CSS布局时容易出的小错误,导致浏览器不兼容或者各种不显示
    使用备份数据库.bal文件还原正在使用的数据库
    sql outer join
    利用GBK双字节编码突破PHP单引号转义限制进行SQL注入:set names gbk导致的sql注入
    对可操作对象的占用状态、锁定状态、解锁状态的一些方案
    回车转换成Tab
    DataGrid超级连接列
  • 原文地址:https://www.cnblogs.com/mofei1999/p/11780149.html
Copyright © 2011-2022 走看看