日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

选举学生会(洛谷P1271题题解,Java/C++语言描述)

發布時間:2025/3/15 c/c++ 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 选举学生会(洛谷P1271题题解,Java/C++语言描述) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目要求

題目鏈接

分析

題很簡單,但對sort()的效率有要求。

開始用Java寫了一版:

import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.Arrays;public class Main {public static void main(String[] args) throws IOException {BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));reader.readLine();String[] read = reader.readLine().split("\\s+");reader.close();int[] nums = new int[read.length];for (int i = 0; i < nums.length; i++) {nums[i] = Integer.parseInt(read[i]);}Arrays.sort(nums);StringBuilder result = new StringBuilder();for (int i : nums) {result.append(i).append(" ");}System.out.println(result.toString().trim());} }

終究還是T了:

看了看,差的也不少,所以換C++,分析見此:《一文道破快速排序從理解到優化》。

AC代碼(C++)

#include<iostream> using namespace std; int a, num, array[2000001];/*** 應用二分思想* @param left 左索引* @param right 右索引*/ void quickSort(int left, int right) {int mid = array[(left+right)/2];//中間數int i = left, j = right;do {while (array[i] < mid) {i++;//查找左半部分比中間數大的數}while (array[j] > mid) {j--;//查找右半部分比中間數小的數}if (i <= j) {swap(array[i], array[j]);//交換i++;j--;}} while (i <= j);if (left < j) {quickSort(left, j);//遞歸搜索左半部分}if (i < right) {quickSort(i, right);//遞歸搜索右半部分} }int main() {cin >> a >> num;for (int i = 1; i <= num; i++) {cin >> array[i];}quickSort(1, num);for (int i = 1; i <= num; i++) {cout << array[i] << " ";} }

總結

以上是生活随笔為你收集整理的选举学生会(洛谷P1271题题解,Java/C++语言描述)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。