C/C++ 凸多邊形求對角線交點的示例代碼
題目描述
對于一個 n 個頂點的凸多邊形,它的任何三條對角線都不會交于一點。請求出圖形中對角線交點的個數(shù)。
例如,6 邊形:
這里可以注意到并沒有出現(xiàn)多條對角線交叉在一個點的情況。
輸入格式
輸入只有一行一個整數(shù) n,代表邊數(shù)。
輸出格式
輸出一行一個整數(shù)代表答案。
數(shù)據(jù)規(guī)模與約定
這里給出一個特別的例子
輸入是:
98765
輸出是:
3964374251598225115
特別注意,在這種情況下,答案的值已經(jīng)非常逼近longlong類型的最大表示范圍,所以在計算的過程當中要特別注意,下面給出代碼
#include <iostream> using namespace std; int main() { long long int n = 0; cin >> n; long long int answer = 0; long long int temp = 1; while (temp < (n - 2)) { answer += temp * (n - temp - 2); temp++; } if (n % 4 == 0) { n /= 4; } else if (n % 2 == 0) { n /= 2; answer /= 2; } else { answer /= 4; } answer *= n; cout << answer << endl; return 0; }
先選擇一條對角線,將多邊形分為兩個部分,一邊是一個點的,另一邊是剩下的點,兩邊的點相連形成的對角線與所選擇的對角線相交形成交點。
以此類推,現(xiàn)分為一邊是1個點的,然后這一邊的點逐漸增加,直到另外一邊也只剩下一個點為止。需要特別注意的是,這樣的每一組對角線都有n條,這樣重復計算了比如點a到點b和點b到點a,其實是同一條。再根據(jù)題意,每個交點是由兩個對角線形成的,而我們在計算點的時候用每條對角線都計算了一次,所以又重復計算了一遍。也就是說,這樣我們得到的answer是最終正確answer的四倍。
特別注意,我將乘n的操作挪到了外面,把除以4的操作提前了,避免在運算的過程中出現(xiàn)數(shù)據(jù)上溢的情況。
到此這篇關于C/C++ 凸多邊形求對角線交點的文章就介紹到這了,更多相關C++ 凸多邊形求對角線交點內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
C語言實現(xiàn)大數(shù)值金額大寫轉(zhuǎn)換的方法詳解
這篇文章主要為大家詳細介紹了如何利用C語言實現(xiàn)大數(shù)值金額大寫轉(zhuǎn)換的功能,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起了解一下2023-03-03Qt數(shù)據(jù)庫應用之實現(xiàn)數(shù)據(jù)打印到紙張
關于Qt打印內(nèi)容到紙張,網(wǎng)上的辦法非常多,比如有些直接用painter繪制,逐步控制分頁打印。本文介紹的方法則是將內(nèi)容作為html設置到文檔對象,再調(diào)用文檔對象的print方法傳入QPrinter對象打印,感興趣的同學可以了解一下2022-01-01C++17 使用 std::string_view避免字符串拷貝優(yōu)化程序性能
這篇文章主要介紹了C++17 使用 std::string_view避免字符串拷貝優(yōu)化程序性能,幫助大家提高程序運行速度,感興趣的朋友可以了解下2020-10-10C++ 面向?qū)ο蟪绦蛟O計--內(nèi)存分區(qū)詳解
這篇文章主要介紹了剖析C++的面向?qū)ο缶幊趟枷?C++的面向?qū)ο筇匦允瞧鋵語言的重要拓展之處,需要的朋友可以參考下,希望能夠給你帶來幫助2021-08-08