兩種常用的C語言排序演算法

来源:http://www.cnblogs.com/xiao-c-2016/archive/2016/09/24/5903274.html
-Advertisement-
Play Games

1. 要求輸入10個整數,從大到小排序輸出 輸入:2 0 3 -4 8 9 5 1 7 6 輸出:9 8 7 6 5 3 2 1 0 -4 解決方法:選擇排序法 實現代碼如下: #include <stdio.h> int main(int argc, const char * argv[]) { ...


1.

要求輸入10個整數,從大到小排序輸出

輸入:2 0 3 -4 8 9 5 1 7 6

輸出:9 8 7 6 5 3 2 1 0 -4

 

解決方法:選擇排序法

實現代碼如下:

#include <stdio.h>

int main(int argc, const char * argv[]) {

    int num[10],i,j,k,l,temp;

    //用一個數組保存輸入的數據

    for(i=0;i<=9;i++)

    {

        scanf("%d",&num[i]);

    }

    //用兩個for嵌套迴圈來進行數據大小比較進行排序

    for(j=0;j<9;j++)

    {

        for(k=j+1;k<=9;k++)

        {

            if(num[j]<num[k]) //num[j]<num[k]

            {

                temp=num[j];

                num[j]=num[k];

                num[k]=temp;

            }

        }

    }

    //用一個for迴圈來輸出數組中排序好的數據

    for(l=0;l<=9;l++)

    {

        printf("%d ",num[l]);

    }

    return 0;

}

 

 

2.

要求輸入10個整數,從大到小排序輸出

輸入:2 0 3 -4 8 9 5 1 7 6

輸出:9 8 7 6 5 3 2 1 0 -4

 

解決方法:冒泡排序法

實現代碼如下:

#include <stdio.h>

int main(int argc, const char * argv[]) {

    //用一個數組來存數據    

    int num[10],i,j,k,l,temp;    

    //用for來把數據一個一個讀取進來   

    for(i=0;i<=9;i++)        

    {        

        scanf("%d",&num[i]);        

    }

     //用兩次層for迴圈來比較數據,進行冒泡    

    for(j=0;j<9;j++) 

    {   

        for(k=0;k<9-j;k++)   

        { 

            if(num[k]<num[k+1]) //num[k]<num[k+1]       

            { 

                temp=num[k];

                num[k]=num[k+1];

                num[k+1]=temp;  

            }  

        }  

    }

    //用一個for迴圈來輸出數組中排序好的數據

    for(l=0;l<=9;l++)

    {

       printf("%d ",num[l]);  

    }    

    return 0;

}


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • import java.util.*;import java.math.*;public class CaculatorLnN { public static void main(String[] args) { // TODO 自動生成的方法存根 int N; System.out.println ...
  • 網上目前還找不到完整的mac下golang環境配置支持,本人配置成功,現在整理分享出來。 mac最好裝下xcode,好像有依賴關係安裝Homebrew打開終端視窗, 粘貼腳本執行/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent. ...
  • 1、考慮用靜態工廠方法代替構造器 類的一個實例,通常使用類的公有的構造方法獲取。也可以為類提供一個公有的靜態工廠方法(不是設計模式中的工廠模式)來返回類的一個實例。例如: 使用靜態工廠方法代替構造器的優勢: 靜態工廠方法有名稱,更易讀。靜態工廠方法能夠使用方法名稱進行自註釋,來描述被返回的對象。例如 ...
  • restful服務中一個重要的特性就是一種資源可以有多種表現形式,在springmvc中可以使用ContentNegotiatingViewResolver這個視圖解析器來實現這種方式。 描述資源的三種形式 一、使用擴展名 http://localhost:8080/test/user.xml 以x ...
  • 獲取數據是數據分析中必不可少的一部分,而網路爬蟲是是獲取數據的一個重要渠道之一。鑒於此,我拾起了Python這把利器,開啟了網路爬蟲之路。 本篇使用的版本為python3.5,意在抓取證券之星上當天所有A股數據。程式主要分為三個部分:網頁源碼的獲取、所需內容的提取、所得結果的整理。 一、網頁源碼的獲 ...
  • gson是一個google的開源項目,支持多種JSON方法,這裡主要講解如何使用gson將json轉換成javaBean。 maven坐標 java代碼: 上述代碼代碼中涉及到java內部類的聲明 ,這裡補充一個知識點,關於java內部類就是在一個類裡面定義另一個類,要聲明一個內部類的語法是: Ou ...
  • 本渣渣鴿了一個月終於有時間更新。因為有c++基礎,學起來這章還是比較簡單的,本章我覺得是程式猿質變課程,理解面向對象的思想,掌握面向對象的基本原則以及 Java 面向對象編程基本實現原理,熟練使用封裝、繼承、多態面向對象三大特性,感受和c++之間的異同,下麵是學習路線。 1.類和對象 1-1 什麼是 ...
  • 1.創建一個web工程 2.導入jar包 3.創建Student表 4.創建實體類 5.配置映射文件 6.配置主配置文件 7.創建一個工具類 8.創建分頁實體類 9.創建Dao類 10.實現Dao介面 11.創建業務層的介面 12.實現業務層介面 13.創建Servlet類 Servlet類里的增刪 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...