PTA 1002 A+B for Polynomials

来源:https://www.cnblogs.com/shenc9ea/archive/2020/04/24/12764828.html
-Advertisement-
Play Games

題目翻譯 現在,你需要求出A,B兩個多項式的相加結果。 輸入要求 每一個輸入文件包含一個測試樣例。每一個樣例占兩行並且每行包含多項式的信息: $K\space N_1 \space a_{N_1}\space N_2 \space a_{N_2} \space ...\space N_k \spac ...


題目翻譯

現在,你需要求出A,B兩個多項式的相加結果。

輸入要求

每一個輸入文件包含一個測試樣例。每一個樣例占兩行並且每行包含多項式的信息:

\(K\space N_1 \space a_{N_1}\space N_2 \space a_{N_2} \space ...\space N_k \space a_{N_k}\)

這裡K代表多項式中非零項的數量,\(N_i\)\(a_{N_i}\)(\(i\)=1,2,...,K)分別是指數(exponents)和繫數(coefficients)。\(1\leq K\leq 10\),\(0\leq N_K<...< N_2<N_1\leq1000\).

輸出要求

對於一個測試樣例,你需要在一行以相同格式輸出A和B的和。註意行尾沒有多餘的空格。請精確到小數點後一位。

樣例輸入

2 1 2.4 0 3.2
2 2 1.5 1 0.5

樣例輸出

3 2 1.5 1 2.9 0 3.2

分析:因為題上沒有說是按照從大到小的順序輸入的,並且在我經過測試後也發現輸入時指數的順序是混亂的。 所以我一開始的想法是建兩個鏈表,鏈表裡每個節點都是都存儲繫數和指數,然後把鏈表排序後再相加。但一想到要寫鏈表的排序演算法我就放棄了,而且代碼出錯的概率太高了。

​ 之後在看過大佬的們的題解後,發現可以用類似桶排序的方法做。就是先開一個比指數的上限還要大的數組,裡面全都初始化成0,然後讀取一對指數和繫數,就把指數對應的項加上讀取繫數的值。之後先從小到大數一遍非0項的個數,再從大到小輸出即可。時間複雜度是\(O_{(n)}\)

​ 廢話不多說,直接上代碼。

#include <stdio.h>
#define KMAX 1001
float cof[KMAX];

int main()
{
    int k;
    scanf("%d", &k);
    int e;    //e和c分別用來臨時存儲讀取的指數和繫數
    float c;
    for (int i = 0; i < k; i++)
    {
        scanf("%d%f", &e, &c);
        cof[e] = c;     
    }
    scanf("%d", &k);
    for (int i = 0; i < k; i++)
    {
        scanf("%d%f", &e, &c);
        cof[e] += c;    //註意這裡要用+=,因為A,B有相同的指數時,要加在一起
    }

    int cot = 0;
    for (int i = 0; i < KMAX; i++)     //先正序遍歷一遍,計算項的個數
        if (cof[i] != 0)
            cot++;
    printf("%d", cot);
    for (int i = KMAX - 1; i >= 0; i--)    //最後倒序輸出
        if (cof[i] != 0)
            printf(" %d %.1f", i, cof[i]);
    return 0;
}

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

-Advertisement-
Play Games
更多相關文章
  • 問題:在一個固定長度的位置(例如標題欄),針對其內容的字數不定的情況下,如何實現總是能展示完整的標題? 解法: 1、定義獲取字元串位元組數的函數(註意是位元組數不是長度) 2、根據字元串位元組數調整字體大小(成反比,且可以使用Math.cos,具體根據實際情況來調整) String.prototype.b ...
  • 在Visual Studio Code 1.設置. show tabs 取消打勾,再次打勾 2.關閉預覽功能。 設置中搜索 workbench.editor.enablePreview ,找到此項後,保持不勾選狀態,這樣就會關閉了預覽模式,打開的文件都會生成新的標簽頁。 參考: https://bl ...
  • 把拖動div功能用react封裝成class,在頁面直接引入該class即可使用。 title為可拖動區域。panel為要實現拖動的容器。 優化了拖動框超出頁面範圍的情況,也優化了拖動太快時滑鼠超出可拖動區域的情況,優化了拖動會卡頓的情況。 頁面中添加引入方法: <Draggable panelId ...
  • 最近客戶反映頁面會有亂碼的情況,查看後發現只有英文大寫字母亂了 谷歌瀏覽器有翻譯功能,在翻譯成中文後會出現這種情況。 <html id="html" lang="zh-CN">之前lang=“en”,如果瀏覽器設置了總是詢問,在檢測到是en後會提示是否翻譯。發現在翻譯後,html的lang會變化,然 ...
  • 前端是什麼? 工作流程為從UI處得到原型圖或者效果圖,在項目(網站、微信公眾號、小程式、WEBAPP)中還原圖片效果,然後與後臺進行各種數據交互。 目前的前端市場整體還是處於迅速發展期,市場對於前端的需求也一直比較大。市場對於中高級的前端工程師需求更加迫切,所以就算入了前端的門,也需要不斷的提升自己 ...
  • 一、垃圾回收機制的必要性 由於字元串、對象和數組沒有固定大小,所以當它們的大小已知時,才能對它們進行動態的存儲分配。JavaScript程式每次創建字元串、數組或對象時,解釋器都必須分配記憶體來存儲那個實體。只要像這樣動態地分配了記憶體,最終都要釋放這些記憶體以便它們能夠被再用,否則,JavaScript ...
  • 一、什麼是架構 我想這個問題,十個人回答得有十一個答案,因為另外的那一個是大家妥協的結果,哈哈,我理解,架構就是骨架,如下圖所示: 人類的身體的支撐是主要由骨架來承擔的,然後是其上面的肌肉、神經、皮膚。架構對於軟體的重要性不亞於骨架對人類身體的重要性。 二、什麼是設計模式 這個問題我問過的面試者不下 ...
  • 1.事務控制的理解 事務控制的慨念這裡不作說明。事務控制的不好可能會造成資料庫數據的臟讀,污讀 舉個例子:轉賬的功能 張三給李四轉錢,各自的賬號金額操作完成後,需要各自更新到資料庫,此時如果張三更新完後,程式異常了結束了,使得李四的賬戶沒有更新,使得總金額不對 為了控制這種數據的不合理,引進了事務。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...