# APCS 2016年10月 實作1 - 三角形辨別 ## 題目敘述 三角形除了是最基本的多邊形外,亦可進一步細分為鈍角三形、直角三角形及銳角三角形。若給定三個線段的長度,透過下列公式運算,即可得知此三線段能否構成三角形,亦可判斷是直角、銳角和鈍角三角形。 提示:若a、b、c為三個線段的邊長,且c為最大值,則 若 a+b ≦ c ,三線段無法構成三角形 若 a×a+b×b < c×c ,三線段構成鈍角三角形(Obtuse triangle) 若 a×a+b×b = c×c ,,三線段構成直角三角形(Right triangle) 若 a×a+b×b > c×c ,三線段構成銳角三角形(Acute triangle) 請設計程式以讀入三個線段的長度判斷並輸出此三線段可否構成三角形?若可,判斷 並輸出其所屬三角形類型。 ### 輸入說明 輸入僅一行包含三正整數,三正整數皆小於 30,001,兩數之間有一空白。 ### 輸出說明 輸出共有兩行,第一行由小而大印出此三正整數,兩字之間以一個空白格間格,最後 一個數字後不應有空白;第二行輸出三角形的類型: 若無法構成三角形時輸出「No」; 若構成鈍角三形時輸出「Obtuse」; 若直角三形時輸出「Right」; 若銳角三形時輸出「Acute」。  **提示:** 提示 : (範例一說明) a×a + b×b = c×c 成立時為直角三形。 (範例二說明) 邊長排序由小到大輸出, a×a a×a + b×b > c×c 成立時為銳角三形。 (範例三說明) 由於無法構成三角形,因此第二行須印出「No」。 評分說明:輸入包含若干筆測試資料,每一筆測試資料的執行時間限制 (time limit) 均為1秒,依正確通過測資筆數給分 ## 程式碼 ```cpp= #include <bits/stdc++.h> using namespace std; int main(){ int a, b, c; cin >> a >> b >> c; vector<int> data = {a, b, c}; sort(data.begin(), data.end()); for(int i=0; i<3; i++){ cout << data[i] << " "; } cout << endl; if(data[0] + data[1] < data[2]){ cout << "No" << endl; }else if(data[0]*data[0] + data[1]*data[1] < data[2]*data[2]){ cout << "Obtuse" << endl; }else if(data[0]*data[0] + data[1]*data[1] == data[2]*data[2]){ cout << "Right" << endl; }else{ cout << "Acute" << endl; } } ``` ## 執行結果  ## 資料來源 [https://zerojudge.tw/ShowProblem?problemid=c294](https://zerojudge.tw/ShowProblem?problemid=c294)
×
Sign in
Email
Password
Forgot password
or
By clicking below, you agree to our
terms of service
.
Sign in via Facebook
Sign in via Twitter
Sign in via GitHub
Sign in via Dropbox
Sign in with Wallet
Wallet (
)
Connect another wallet
New to HackMD?
Sign up