//升序、降序算法

//升序、降序算法

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

public class Bub
{
 
 int  arr[];
 
 String a[];
 
 int  temp;
 
 public Bub()
 {}
 void sort1(String[] a)
 {
  arr = new int[a.length];
  for (int i = 0; i <a.length; i++)
  {
   arr[i] = Integer.parseInt(a[i]);
  }
  for (int i = 0; i <= 9; i++)
  {
   for (int j = 9; j > i; j--)
   {
    if (arr[i] > arr[j])
    {
     temp = arr[i];
     arr[i] = arr[j];
     arr[j] = temp;
    }
   }
  }
  System.out.print("the first sorting is" + "\n");
  for (int i = 0; i < 10; i++)
  {
   System.out.print(" " + arr[i]);
  }
  System.out.print("\n" + "**************************" + "\n");
 }
 
 
 
 /**
  * @param args
  * @throws IOException
  */
 public static void main(String[] args) throws IOException
 {
  // InputStream obj = new InputStream();
  
  BufferedReader obj = new BufferedReader(new InputStreamReader(System.in));
  String[] text = new String[10];
  for (int i = 0; i < text.length; i++)
  {
   text[i] = obj.readLine();
   if ("quit".equals(obj))
   {
    break;
   }
  }
  obj.close();
  Bub obj1 = new Bub();
  // obj1.sort1(args);
  obj1.sort1(text);
 }
}

当然可以。在Python中,我们可以使用循环算法来实现排序。这里我会分别介绍两种常见的排序算法:冒泡排序(升序降序)以及选择排序。 ### 1. 冒泡排序 (升序) ```python def bubble_sort_asc(arr): n = len(arr) for i in range(n): # 每一轮遍历都会把最大的元素"冒泡"到最后 for j in range(0, n - i - 1): if arr[j] > arr[j + 1]: arr[j], arr[j + 1] = arr[j + 1], arr[j] return arr # 示例 arr_asc = [64, 34, 25, 12, 22, 11, 90] sorted_arr_asc = bubble_sort_asc(arr_asc) print("升序排序后的数组:", sorted_arr_asc) ``` ### 2. 冒泡排序 (降序) ```python def bubble_sort_desc(arr): n = len(arr) for i in range(n): # 每一轮遍历都将最小的元素"冒泡"到最前面 for j in range(0, n - i - 1): if arr[j] < arr[j + 1]: arr[j], arr[j + 1] = arr[j + 1], arr[j] return arr # 示例 arr_desc = [64, 34, 25, 12, 22, 11, 90] sorted_arr_desc = bubble_sort_desc(arr_desc) print("降序排序后的数组:", sorted_arr_desc) ``` ### 3. 选择排序 (升序/降序) ```python def selection_sort_asc(arr): for i in range(len(arr)): min_index = i for j in range(i+1, len(arr)): if arr[j] < arr[min_index]: min_index = j arr[i], arr[min_index] = arr[min_index], arr[i] return arr def selection_sort_desc(arr): for i in range(len(arr)): max_index = i for j in range(i+1, len(arr)): if arr[j] > arr[max_index]: max_index = j arr[i], arr[max_index] = arr[max_index], arr[i] return arr # 示例 arr_asc = [64, 34, 25, 12, 22, 11, 90] sorted_arr_asc = selection_sort_asc(arr_asc) print("升序排序后的数组:", sorted_arr_asc) arr_desc = [64, 34, 25, 12, 22, 11, 90] sorted_arr_desc = selection_sort_desc(arr_desc) print("降序排序后的数组:", sorted_arr_desc) ``` 如果你想了解其他排序算法如插入排序、快速排序等,或是有特定需求,请告诉我。此外,对于大规模数据,这些简单的排序算法效率可能不高,考虑使用内置的`sorted()`或`list.sort()`方法更为合适。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值