暴力+輾轉相除法——N個數求和

来源:https://www.cnblogs.com/Louise-Zhou/archive/2020/03/24/Louise_Z.html
-Advertisement-
Play Games

從題目“分子/分母”的輸入形式可以看出我們不能採用scanf和cin直接輸輸入值 而要採用字元輸入再轉換為數值 計算過程中判斷好符號 暴力通分直接加減即可 防止通分過程超出長整型範圍 最好每一步結果都約分 我最開始暴力約分來著 發現會超時 就用歐幾裡得演算法了 不麻煩也不會超時 輸出時註意題目... ...


題目來源

PTA 團體程式設計天梯賽-練習集 L1-009 N個數求和 (20分)

https://pintia.cn/problem-sets/994805046380707840/problems/994805133597065216

 

題目描述

本題的要求很簡單,就是求N個數字的和。麻煩的是,這些數字是以有理數分子/分母的形式給出的,你輸出的和也必須是有理數的形式。

輸入格式:

輸入第一行給出一個正整數N(≤100)。隨後一行按格式a1/b1 a2/b2 ...給出N個有理數。題目保證所有分子和分母都在長整型範圍內。另外,負數的符號一定出現在分子前面。

輸出格式:

輸出上述數字和的最簡形式 —— 即將結果寫成整數部分 分數部分,其中分數部分寫成分子/分母,要求分子小於分母,且它們沒有公因數。如果結果的整數部分為0,則只輸出分數部分。

樣例:

輸入樣例1:

5
2/5 4/15 1/30 -2/60 8/3

輸出樣例1:

3 1/3

輸入樣例2:

2
4/3 2/3

輸出樣例2:

2

輸入樣例3:

3
1/3 -1/6 1/8

輸出樣例3:

7/24

 

思路

從題目“分子/分母”的輸入形式可以看出我們不能採用scanf和cin直接輸輸入值 而要採用字元輸入再轉換為數值

計算過程中判斷好符號 暴力通分直接加減即可

防止通分過程超出長整型範圍 最好每一步結果都約分

我最開始暴力約分來著 發現會超時 就用歐幾裡得演算法了 不麻煩也不會超時

輸出時註意題目要求的形式 想仔細一點每種條件怎麼輸出即可

 

代碼

 1 #include <cstdio>
 2 using namespace std;
 3 int n,o=1,oo; char x=1; //o-結果是否為非負數 oo-當前輸入的有理數是否為非負數
 4 long long p,q,f=0,g=1,c;
 5 inline long long read(); //快讀 由於分子分母間有‘/’分隔且分母一定是正數 標準快讀模板即可完成
 6 inline int yue(long long a,long long b);//求a和b的最大公約數
 7 int main()
 8 {
 9   scanf("%d",&n); 
10   for(int i=1;i<=n;i++)
11   {
12     while(!(x>=48&&x<=57)&&x!='-')
13       x=getchar();
14     if(x=='-') oo=0;
15     else    oo=1; //判斷當前輸入的有理數是否為非負數
16     p=read();
17     q=read(); //以“|p/q|”形式讀入當前有理數
18     p*=g;
19     f*=q;
20     g*=q; //暴力通分 本題數據範圍內沒有超出長整型
21     if((o&&oo)||(!o&&!oo)) //如果結果和當前輸入有理數同號 只要分子絕對值部分相加即可
22       f+=p;
23     else if(o&&!oo) //如果結果為正 當前輸入有理數為負 則需要比較結果與當前輸入有理數的大小來確定此次運算後結果的符號 
24     {
25       if(f>=p) //當前結果大於當前輸入有理數的絕對值 結果仍為正數 以下同理 
26         f-=p;
27       else
28         o=0,f=p-f;
29     }
30     else if(!o&&oo)
31     {
32       if(f>=p)
33         o=1,f-=p;
34       else
35         f=p-f;
36     }
37     int u=yue(f,g); //u為f和g的最大公約數
38     f/=u;
39     g/=u; //約分
40   }
41   if(o==0) printf("-"); //如果結果是負數 輸出負號
42   if(f==0)    printf("0"); //如果結果是0 輸出0
43   else if(f%g==0)    printf("%lld",f/g); //如果結果可以約分為整數
44   else if(g%f==0) printf("1/%lld",g/f);//如果結果可以約分為“1/x”形式
45   else if(f>g) //如果結果的分子大於分母 即結果為假分數 需要轉化為帶分數
46   {
47     printf("%lld ",f/g); //整數部分
48     f%=g;
49     printf("%lld/%lld",f,g); //分數部分
50   }
51   else
52     printf("%lld/%lld",f,g); //如果結果為真分數
53   return 0;
54 }
55 inline int yue(long long a,long long b) //歐幾裡得演算法 親測暴力約分會超時
56 {
57   if(a>b) c=a,a=b,b=c; 
58   while(a!=0) //
59   {
60     while(b>=a) //標準%運算比較慢 直接減
61       b-=a;
62     c=a,a=b,b=c;
63   }
64   return b;
65 }
66 inline long long read()
67 {
68   long long s=0;
69   while(!(x>=48&&x<=57))
70     x=getchar();
71   while(x>=48&&x<=57)
72     s*=10,s+=x-48,x=getchar();
73   return s;
74 }

 

吐槽

很少見到PTA這樣AC紅WA綠的平臺了 屬實清新脫俗:)


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

-Advertisement-
Play Games
更多相關文章
  • E. Efficient Exchange 題意:這一題的題意簡單;簡單來說就是A、B有1元10元、100元、1000元。。。。等等10的整次冪的票額的紙幣,現在B付錢給A,問當中涉及錢的張數最少是多少可以把錢付清。 題解:這一題官方題解給的是DP+遞歸,自己看了半天,代碼中的註釋給出了自己的理解, ...
  • 1 簡介 項目越做越發覺得,任何一個系統上線,運維監控都太重要了。關於Springboot微服務的監控,之前寫過 "【Springboot】用Springboot Admin監控你的微服務應用" ,這個方案可以實時監控並提供告警提醒功能,但不能記錄歷史數據,無法查看過去1小時或過去1天等運維情況。本 ...
  • 一、對象類文件的序列換與反序列化 1.java.io.ObjectOutputStream;序列化JAVA對象到硬碟 2.java.io.ObjectInputStream;將硬碟中的數據“反序列化”到JVM記憶體中 Compile編譯(java->class) DeCompile反編譯(class- ...
  • 什麼場景該使用通用計價 如果商品的費用屬性一直在變化,比如隔三岔五的新增某種費用(按新規則計算的新費用),作為開發人員的你每次需要膽戰心驚的維護現有的計價介面,測試也需要花費大量時間驗證對其他費用的影響。基於這一點,我在想如果初期把計價做成一個通用的計價介面,每次加費用我只需要關註新費用的計算規則, ...
  • 繼承的優點:減少代碼的冗餘 提高代碼的重用性 派生類定義格式: Class 派生類名 : 繼承方式 基類名{ //派生類新增的數據成員和成員函數 }; class 子類: 繼承方式 父類名{ //子類新增的數據成員和成員函數 }; 繼承方式分類: public : 公有繼承 (重要) private ...
  • 什麼是defer? defer語句是專門在函數結束以後做一些清理工作的。我們先舉一個例子來更好的理解,現在有一個函數,它的作用是把一個文件內容拷貝到另一個文件。 以上代碼是可以正常執行的,但是存在一個問題,如果os.Create執行失敗,那麼就無法執行到文件資源的Close函數。進程每打開一個文件就 ...
  • Java中的匿名對象 1. 什麼是匿名對象? 所謂匿名對象就是沒有名稱的對象; 2. 匿名對象有哪些常見的用法? + 匿名對象可以作為實際參數傳遞給函數; + 可以直接通過匿名對象調用該對象的方法; 3. 匿名對象的具體使用方式 ...
  • 說明: 作為反射工具類,通過對象和屬性的名字獲取對象屬性的值,如果在當前對象屬性沒有找到,依次向上收集所有父類的屬 性,直到找到屬性值,沒有找到返回null; 代碼: 1.classUtil package com.example.demo.utill; import java.lang.refle ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...