【Coursera 计算导论与C语言基础】冒泡+奇偶排序

编程题#1:实现冒泡排序
来源: POJ (Coursera声明:在POJ上完成的习题将不会计入Coursera的最后成绩。)

注意: 总时间限制: 1000ms 内存限制: 65536kB

描述
请根据自己的理解编写冒泡排序算法,数组大小1000以内

输入
第一行是n,表示数组的大小

接着n行是数组的n个元素

输出
排序之后的结果

一个元素一行

#include <iostream>
 using namespace std;

 int main() {
     int n, a[1000]; // 一共n个数,n不超过1000。a用来保存这些数
     cin >> n;  
     // 输入n个数  
     for (int i = 0; i < n; i++) {
       cin >> a[i];
 } // 冒泡,不断比较相邻的两个数,如果顺序错了,那么就交换
 for (int i = 0; i < n - 1; i++) {
   for (int j = 1; j < n - i; j++) {      
     if (a[j - 1] > a[j]) {
       int temp = a[j];
       a[j] = a[j - 1];
       a[j - 1] = temp;
     }    
   }  
 }  
 // 依次输出
for (int i = 0; i < n; i++) {
  cout << a[i] << endl;   
  }  
   return 0;
}

编程题#2:奇偶排序(一)
来源: POJ (Coursera声明:在POJ上完成的习题将不会计入Coursera的最后成绩。)

注意: 总时间限制: 1000ms 内存限制: 65536kB

描述
输入十个整数,将十个整数按升序排列输出,并且奇数在前,偶数在后。

输入
输入十个整数

输出
按照奇偶排序好的十个整数

    #include <iostream>
    using namespace std;
    
    int main() {
      int a[10];
      for (int i = 0; i < 10; i++) {
        cin >> a[i];
      }
      // 首先,我们把奇数放到数组左边,偶数放到数组右边
      int l = 0, r = 9; //用左手和右手分别指向数组两端
      while (l <= r) {
        bool leftIsOdd = a[l] % 2 == 1;
        bool rightIsEven = a[r] % 2 == 0;
        if (leftIsOdd) {
          l++;
        } else if (rightIsEven) {
          r--;
        } else if (!leftIsOdd && !rightIsEven) {
          int temp = a[l];
          a[l] = a[r];
          a[r] = temp;
        }
      }
      // 对l左边(奇数部分)冒泡,不断比较相邻的两个数,如果顺序错了,那么就交换
      int start = 0, end = l;
      for (int i = start; i < end - 1; i++) {
        for (int j = start + 1; j < start + end - i; j++) {
          if (a[j - 1] > a[j]) {
            int temp = a[j];
            a[j] = a[j - 1];
            a[j - 1] = temp;
          }
        }
      }
      // 对l右边(偶数部分)冒泡,不断比较相邻的两个数,如果顺序错了,那么就交换
      start = l, end = 10;
      for (int i = start; i < end - 1; i++) {
        for (int j = start + 1; j < start + end - i; j++) {
          if (a[j - 1] > a[j]) {
            int temp = a[j];
            a[j] = a[j - 1];
            a[j - 1] = temp;
          }
        }
      }
      for (int i = 0; i < 10; i++) {
        cout << a[i] << ' ';
      }
      return 0;
    }

第二种解法

    #include <iostream>
    using namespace std;
    
    int main() {
      int a[10];
      for (int i = 0; i < 10; i++) {
        cin >> a[i];
      }  
      // 冒泡,不断比较相邻的两个数,如果顺序错了,那么就交换
      for (int i = 0; i < 9; i++) {
        for (int j = 1; j < 10 - i; j++) {      
      // 与刚才的冒泡排序不同,我们不只是通过较数字的大小决定顺序
      // 如果左边的为偶数,右边的为奇数,那么顺序也需要颠倒
      bool leftIsEven = a[j - 1] % 2 == 0;
      bool rightIsEven = a[j] % 2 == 0;
      if ((leftIsEven && !rightIsEven) ||
          (leftIsEven == rightIsEven && a[j - 1] > a[j])) {        
        int temp = a[j];        
        a[j] = a[j - 1];
        a[j - 1] = temp;
      }
    }
  }  
  for (int i = 0; i < 10; i++) {
    cout << a[i] << ' ';
  }  
  return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值