Re: [問題] tuple如何用for迴圈取值

作者: poyenc (髮箍)   2020-07-02 04:47:11
※ 引述《nevak (^o^)》之銘言:
: 雖然原文有點長不過聽起來應該就是做參數的Cartesian product
: Python有人說過了秒解XD,C++當作練習其實也滿不錯的
: 這應該面試也常常會考吧XD
: Cartesian product最直覺就DFS走一次
: 實作上來說,看你最後是要給system()用,其實直接把參數做成string應該會單純很多
: 如果你一開始的那些參數的列表一定要用不同型態的vector的話
: 就會有點麻煩需要用template https://glot.io/snippets/fou4l2ksnm
: 如果你那些參數列表都用vector<string>來宣告的話
: 就把所有參數訂在vector<vector<string>>,練習寫個DFS吧
: 應該是不會需要用到tuple
為了怕初學者誤解這裡的程式碼, 還是單獨回一篇.
因為許多人學習 C++ 的管道並不是書籍, 而是網路上的文章, 再加上從
程式碼範例望文生義, 最終理解就會和語言設計不同.
首先來談談 auto 修飾符的用法. auto 依賴使用者完全知道給定的敘述
型別為何, 不然不僅無法寫出型別安全 (type safe) 的程式, 反而還造
成潛在問題 (auto 是為了型別安全而設計, 雖然也帶來便利性, 但後者
不是主要目的). 如下面的例子:
std::array values{1, 2, 3};
for (auto idx = 0; idx < size(values); ++idx) {
~~~~^~~~~~~~~~~~~~ error
std::cout << "values[" << idx
<< "] = " << values[idx] << std::endl;
}
為了解決這個問題 C++23 導入了 uz/z 整數後綴 [P0330], 只是標準庫
先迎來了 ssize() 函式 [P1227]. auto 在源頭盡可能地省下轉型成本,
卻導致了我們在後續使用上需小心別掉入自己的假設陷阱.
再來是 initializer list (語法) 的使用, 除了可拿來初始化陣列以及
結構物件, 加強版功能率先在 [N1509] 被提出來, 主要為支援以下兩種
情境:
1. initializer list 拿來當敘述使用 (間接功能)
2. initializer list 拿來初始化容器 (主要功能)
在 C++11 以前, 初始化物件非常麻煩, 遂出現許多冗餘的寫法:
// case #1
struct S { int a, b; };
void f(S);
S s;
s.a = 1;
s.b = 2;
f(s); // method #1, error prone
f({1, 2}); // method #2, need C++11 support
// case #2
int a[] = {0, 1, 2};
std::vector<int> v(a, a + 3); // method #1, error prone
std::vector<int> v2 = {0, 1, 2}; // method #2, need C++11 support
最開始還只是語言支援, 後來才導入 std::initializer_list 代理物件
的概念 [N2215] 來幫助編譯器在遇到使用 initializer list 初始化物
件時, 選用合適的建構子呼叫. 在這之後幾乎所有容器都加入了接受
std::initializer_list 的多載建構子版本 [N2679].
所以嚴格說起來用 auto 來接 std::initializer_list 物件並不是後者
的設計本意, 它本身不算是容器, 而是作為容器的初始化介面型別 (所
以不存在 assign()/erase() 等成員函式). 雖然這份程式碼還是編譯得
過, 但在 C++ 社群裡幾乎不會有這種非正規用法.
References
[P0330R8] Literal Suffixes for (signed) size_t
https://wg21.link/p0330r8
[P1227R2] Signed ssize() functions, unsigned size() functions
https://wg21.link/p1227r2
[N1509] Generalized Initializer Lists
https://wg21.link/n1509
[N2215] Initializer lists (Rev. 3)
https://wg21.link/n2215
[N2679] Initializer Lists for Standard Containers (Revision 1)
https://wg21.link/n2679
作者: nevak (^o^)   2020-07-02 09:53:00
感謝說明,auto = {}確實是當時我偷懶的寫法,希望大家別在正式的code這樣寫。
作者: Dracarys (MayShowGunMore)   2020-07-02 12:21:00
哇 大神不睡覺的?
作者: Jockey66666 (往事已成追憶)   2020-07-02 23:58:00
已跪
作者: lc85301 (pomelocandy)   2020-07-03 08:02:00
c++23 ....
作者: KevinR (Kevin)   2020-07-05 08:17:00

Links booklink

Contact Us: admin [ a t ] ucptt.com