北郵機試真題2009

来源:https://www.cnblogs.com/han-zh/archive/2020/02/29/12369702.html
-Advertisement-
Play Games

題目1 求平均分 輸入:兩行 第一行是分數個數n 第二行是這n個分數,以空格隔開 輸出: 去掉最高分與最低分後的平均成績 #include<stdio.h> float buf[1001]; void fun(int n){ for(int i=0;i<n;i++){ for(int j=0;j<n ...


題目1

求平均分

輸入:兩行

第一行是分數個數n
第二行是這n個分數,以空格隔開

輸出:

去掉最高分與最低分後的平均成績

 

#include<stdio.h>

float buf[1001];

void fun(int n){
    for(int i=0;i<n;i++){
        
        for(int j=0;j<n-i-1;j++){
            if(buf[j+1]<buf[j]){
                float t=buf[j+1];
                buf[j+1]=buf[j];
                buf[j]=t;
            }
        }
    }
}

int main(){
    int n;
    while(scanf("%d",&n)!=EOF){
        if(n==0)break;
        
        for(int i=0;i<n;i++){
            scanf("%f",&buf[i]);
        }
        
        fun(n);
        
        float ans=0;
        
        for(int i=1;i<n-1;i++)
            ans+=buf[i];
        ans=ans/(n-2);
        
        printf("%.2f\n",ans);
    }
    return 0;
}

題目2

密碼

輸入:一行


第一行:26個小寫字母 以空格隔開 如 b a c e u f g h i j k l m n o p q r s t v w x y z d................. v y z r s q
第二行:一個字元串(大寫字母)  如: BUPTZ

輸出:

B用第一行的第二個字母替換,U用第21個替換,P用第('A'-'P'+1)個替換..

#include<stdio.h>

char buf1[101];
char buf2[101];

int main(){
    
    char c;
    
    while(scanf("%c",&c)!=EOF){
        int j=1;
        if(c=='\n')scanf("%c",&c);//上次大迴圈結束c會讀入這個符號 
        while(c!='\n'){
        
            if(c>='a'&&c<='z'&&j<=26)buf1[j++]=c;
            scanf("%c",&c);
        
        }
    
        scanf("%s",buf2);
    
        for(int i=0;buf2[i]!=0;i++){
            int t=buf2[i]-'A'+1;
            buf2[i]=buf1[t];
    
        }
        printf("%s\n",buf2);
    }

return 0;
    } 

題目3

排序

輸入:四行

第一行:個數N1(2 3 4 5 6)
第二行:N1個數,升序排列(序列a)
第三行:個數N2(4 5 6 8 9)
第四行:N2個數,升序排列(序列b)

輸出:N2行

2
3
4
5
5
第i行是,a中小於 b的第i個數 的數的個數

#include<stdio.h>

int a[1001];
int b[1001];



int main(){
    int n1,n2;
    while(scanf("%d",&n1)!=EOF){
        for(int i=0;i<n1;i++){
            scanf("%d",&a[i]);
        }
        scanf("%d",&n2);
        for(int i=0;i<n2;i++){
            scanf("%d",&b[i]);
        }    
    int ans[n2];
    int i,j,t;
    for(i=0,j=0,t=0;i<n1&&j<n2;){
        
        if(a[i]<b[j]){
            t++;
            i++;
            for(int j1=j;j1<n2;j1++)ans[j1]=t;
        }

        else{
            
            j++;
        }
    }


    for(int i=0;i<n2;i++)
        printf("%d\n",ans[i]);
    }
    return 0;
} 

 題目4

哈夫曼編碼中  平均碼長=碼長×碼字出現的概率

如:ABCDE 五個字元的出現次數分別為50 20 5 10 15

那麼,其哈夫曼編碼為A:0   B:10   C:1110   D:1111   E:110

該哈夫曼編碼的平均碼長=(50*1+20*2+5*4+10*4+15*3)/100=1.95

輸入

有多組輸入,每組兩行

第一行:字元的個數 N

第二行:N 個以空格隔開的數,表示這 N 個字元中每個字元出現次數

輸出

輸出該哈夫曼編碼的平均碼長,保留兩位小數

樣例輸入

5
50 20 5 10 15

樣例輸出

1.95
思路1
#include<stdio.h>
#include<queue>
using namespace std;


int main(){
    int n;
    while(scanf("%d",&n)!=EOF){
        priority_queue<int,vector<int>,greater<int> > Q;
        
        double sum=0;
        for(int i=0;i<n;i++){
            int t;
            scanf("%d",&t);
            sum+=t;
            Q.push(t);
            
        }
        
        double ans=0;
        
        while(Q.size()!=1){
            int t1,t2;
            t1=Q.top();
            Q.pop();
            t2=Q.top();
            Q.pop();
            ans+=t1+t2;
            Q.push(t1+t2);
            
        }
        

        printf("%.2lf\n",ans/sum);
        
    }
    
    return 0;
}

 思路2

#include<stdio.h>
#include<queue>
using namespace std;

struct node{
    int h;
    bool operator < (const node &a) const {
        return h>a.h;
    }
};

int main(){
    int n;
    while(scanf("%d",&n)!=EOF){
        priority_queue<node> Q;
        
        double sum=0;
        for(int i=0;i<n;i++){
            node t;
            scanf("%d",&t.h);
            sum+=t.h;
            Q.push(t);
            
        }
        
        double ans=0;
        
        while(Q.size()!=1){
            int t1,t2;
            node tmp;
            t1=Q.top().h;
            Q.pop();
            t2=Q.top().h;
            Q.pop();
            ans+=t1+t2;
            tmp.h=t1+t2;
            Q.push(tmp);
            
        }
        

        printf("%.2lf\n",ans/sum);
        
    }
    
    return 0;
}

 




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

-Advertisement-
Play Games
更多相關文章
  • 設計模式是前人經驗的總結,教大家如何寫出可擴展、可讀、可維護的高質量代碼。設計模式與日常工作中的編碼有直接的關係,直接影響到開發人員的開發能力。 ...
  • 什麼是高階函數:一個函數可以作為參數傳給另外一個函數(一個函數可以用來接收另一個函數作為參數),或者一個函數的返回值為另外一個函數(若返回值為該函數本身,則為遞歸),滿足其一則為高階函數。函數的形參位置必須接受一個函數對象。 代碼理解高階函數的含義: 1 '''函數當做參數被傳遞到另個函數是什麼樣的 ...
  • 一、cookie 1.requests可以自動處理cookie信息 import requests rsp = requests.get("http://www.baidu.com") #如果對方伺服器給傳送過來cookie信息,則可以同通過反饋的cookie屬性得到 #返回一個cookiejar的 ...
  • 不斷的對於某操作重覆調用執行稱為遞歸調用,遞歸函數執行的這個過程中只有進棧(開闢空間),沒有出棧,直到最後一次調用完畢了,才逐個出棧,所以遞歸函數在執行的時候非常的占用記憶體資源;如果執行的次數過多了,會產生記憶體溢出的現象;所以一定要控制遞歸的層數,當符合某一條件時要終止遞歸調用,幾乎所有的遞歸都能用 ...
  • 基於SSM開發倉庫庫存管理系統開發環境: Windows操作系統開發工具: MyEclipse+Jdk+Tomcat+MySql資料庫 源碼及原文鏈接:https://javadao.xyz/forum.php?mod=viewthread&tid=71 運行效果圖 ...
  • 基於JSP+Servlet開發旅游(景點賓館)系統(前臺+後臺): 開發環境: Windows操作系統開發工具: MyEclipse+Jdk+Tomcat+MYSQL資料庫運行效果圖 源碼及原文鏈接:https://javadao.xyz/forum.php?mod=viewthread&tid=6 ...
  • 匿名(lambda)函數: 作用:創始一個匿名函數對象,同 def 類似,但不提供函數名,只是一個表達式,lambda比函數簡單且可以隨時創建和銷毀,有利於減少程式的偶合度。lambda的主體是一個表達式,而不是一個代碼塊。僅僅能在lambda表達式中封裝有限的邏輯進去。lambda 函數擁有自己的 ...
  • 線程的五種狀態 線程從創建到銷毀一般分為五種狀態,如下圖: 1) 新建 當用new關鍵字創建一個線程時,就是新建狀態。 2) 就緒 調用了 start 方法之後,線程就進入了就緒階段。此時,線程不會立即執行run方法,需要等待獲取CPU資源。 3) 運行 當線程獲得CPU時間片後,就會進入運行狀態, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...