(原創) 如何將陣列每個元素減1後,顯示在螢幕上? (C/C++) (C)
Abstract
一個很簡單的題目,來看看C和C++要如何實現。
Introduction
C語言
1 /*
2 (C) OOMusou 2008 http://oomusou.cnblogs.com
3
4 Filename : array_minus_1.c
5 Compiler : Visual C++ 8.0
6 Description : Demo how to minus 1 in each element of array
7 Release : 03/26/2008 1.0
8 */
9 #include <stdio.h>
10
11 void array_display(int *ia, int size) {
12 int i = 0;
13 while(i++ < size)
14 printf("%d ", *ia++);
15 }
16
17 void array_minus_1(int *ia, int size) {
18 int i = 0;
19 while(i++ < size)
20 --*ia++;
21 }
22
23 int main() {
24 int ia[] = {1, 2, 3, 4, 5, 6};
25 int size = sizeof(ia) / sizeof(int);
26 array_display(ia, size);
27 printf("\n");
28 array_minus_1(ia, size);
29 array_display(ia, size);
30 }
2 (C) OOMusou 2008 http://oomusou.cnblogs.com
3
4 Filename : array_minus_1.c
5 Compiler : Visual C++ 8.0
6 Description : Demo how to minus 1 in each element of array
7 Release : 03/26/2008 1.0
8 */
9 #include <stdio.h>
10
11 void array_display(int *ia, int size) {
12 int i = 0;
13 while(i++ < size)
14 printf("%d ", *ia++);
15 }
16
17 void array_minus_1(int *ia, int size) {
18 int i = 0;
19 while(i++ < size)
20 --*ia++;
21 }
22
23 int main() {
24 int ia[] = {1, 2, 3, 4, 5, 6};
25 int size = sizeof(ia) / sizeof(int);
26 array_display(ia, size);
27 printf("\n");
28 array_minus_1(ia, size);
29 array_display(ia, size);
30 }
執行結果
1 2 3 4 5 6
0 1 2 3 4 5
0 1 2 3 4 5
20行
--*ia++;
是比較詭異的一行,若加上括號,就比較明顯了
--(*(ia++));
由於++放在ia之後,ia指標會先取*值,作--減1,最後ia指標在++加一,對下一個元素做運算。
若用C++寫,則非常的精簡。
C++
1 /*
2 (C) OOMusou 2008 http://oomusou.cnblogs.com
3
4 Filename : array_minus_1.cpp
5 Compiler : Visual C++ 8.0
6 Description : Demo how to minus 1 in each element of array
7 Release : 03/26/2008 1.0
8 */
9 #include <iostream>
10 #include <algorithm>
11 #include <functional>
12
13 using namespace std;
14
15 int main() {
16 int ia[] = {1, 2, 3, 4, 5, 6};
17 int size = sizeof(ia) / sizeof(int);
18 copy(ia, ia + size, ostream_iterator<int>(cout, " "));
19 cout << endl;
20 transform(ia, ia + size, ia, bind2nd(minus<int>(),1));
21 copy(ia, ia + size, ostream_iterator<int>(cout, " "));
22 }
2 (C) OOMusou 2008 http://oomusou.cnblogs.com
3
4 Filename : array_minus_1.cpp
5 Compiler : Visual C++ 8.0
6 Description : Demo how to minus 1 in each element of array
7 Release : 03/26/2008 1.0
8 */
9 #include <iostream>
10 #include <algorithm>
11 #include <functional>
12
13 using namespace std;
14
15 int main() {
16 int ia[] = {1, 2, 3, 4, 5, 6};
17 int size = sizeof(ia) / sizeof(int);
18 copy(ia, ia + size, ostream_iterator<int>(cout, " "));
19 cout << endl;
20 transform(ia, ia + size, ia, bind2nd(minus<int>(),1));
21 copy(ia, ia + size, ostream_iterator<int>(cout, " "));
22 }
執行結果
1 2 3 4 5 6
0 1 2 3 4 5
0 1 2 3 4 5
20行
transform(ia, ia + size, ia, bind2nd(minus<int>(),1));
使用transform()對array的每個元素做運算,每個元素使用了minus這個functor,配合bind2nd adapter後,會對array每一個元素減1。
Conclusion
我在蔡明志的一本老書『Turbo C深入解析』中看到--*ia++這種語法,相當漂亮,所以就寫了一個小程式練習一下,然後又覺得這應該可以配合C++的functor,所以又測試了一下,果然相當有趣。
除此之外,一本快20年前的書,竟然還有實用價值,很難想像吧,這就是因為C/C++有標準,無論compiler怎麼更新,還是得依照ISO標準,記得以前寫VB和C#時,只要微軟出了新版本,誰都沒把握舊版的程式是否還能編譯成功,因為VB和C#都是微軟的,他想怎麼改就怎麼改,雖然說是越改越好,但每個版本的相容性令人相當困擾,你能相信現在寫的VB和C#能在20年後的Visual Studio還能編譯成功嗎?不過我確信20年後的Visual Studio還是能編譯我現在寫的C/C++。
Reference
蔡明志, 1991, Turbo C深入解析, 松崗