第一個程序: 演示數組函數是如何運作的。
#include "stdafx.h"
#include <iostream>
using namespace std;
const int ArSize=8;

 /**//* arr實際上并不是數組,而是一個指針。在編寫函數的
* 其余部分時,可以將arr看作是數組。C++將數組名解釋
* 為其第一個元素的地址。
* int sum_arr(int * arr,int n) 這個函數頭也是正確的。
* int * arr和int arr[]含義是相同,都意味著arr是一個int指針
* 但不能在函數體中使用int tip[]來聲明指針
*/
int sum_arr(int arr[],int n); //prototype
int main(int argc, char* argv[])
  {
 int cookies[ArSize]= {1,2,4,8,16,32,64,128};

int sum=sum_arr(cookies,ArSize);
cout<<"Total cookies eaten: "<<sum<<"\n";
return 0;
}

int sum_arr(int arr[], int n)
  {
int total=0;
for(int i=0;i<n;i++)
total=total+arr[i];
return total;
}
第二個程序: cookies和arr的值相同。并且還演示了指針概念如何使sum_arr函數比以前更通用。該程序是用限定符std::而不是編譯指令using來提供對cout和endl的訪問權。
#include "stdafx.h"
#include <iostream>
const int ArSize=8;
int sum_arr(int arr[],int n);
//use std::instead of using directive
int main(int argc, char* argv[])
  {
 int cookies[ArSize]= {1,2,4,8,16,32,64,128};

std::cout<<cookies<<" = array address, ";
// some system require a type cast: unsigned (cookies)
std::cout<<sizeof cookies<<" = sizeof cookies\n";
int sum=sum_arr(cookies,ArSize);
std::cout<<"Total cookies eaten: "<<sum<<std::endl;
sum=sum_arr(cookies,3); //a lie
std::cout<<"First three eaters ate "<<sum<<" cookies.\n";
sum=sum_arr(cookies+4,4);//another lie
std::cout<<"Last four eaters ate "<<sum<<" cookies.\n";
return 0;
}

int sum_arr(int arr[], int n)
  {
int total=0;
std::cout<<arr<<" = arr, ";
// some systems require a type cast: unsigned (arr)

std::cout<<sizeof arr<<" = sizeof arr\n";
for(int i=0;i<n;i++)
total=total+arr[i];
return total;
}
// 注意,地址值和數組的長度將隨系統而異,另外,有些C++實現將以十進制而不是十六進制格式顯示地址。
 /**//* 為將數組類型和元素數量告訴數組處理函數,請通過兩個不同的參數來傳遞它們:
* void fillArray(int arr[],int size);//prototype
* 而不要試圖使用方括號表示法來傳遞數組長度
* void fillArray(int arr[size]);//No--bad prototype
*/
第三個程序:
#include "stdafx.h"
#include <iostream>
using namespace std;
const int Max=5;

// function prototypes
int fill_array(double ar[], int limit);
void show_array(const double ar[], int n);// don't change data
void revalue(double r, double ar[], int n);
int main(int argc, char* argv[])
  {
double properties[Max];

int size=fill_array(properties,Max);
show_array(properties,size);
cout<<"Enter revaluation factor: ";
double factor;
cin>>factor;
revalue(factor,properties,size);
show_array(properties,size);
cout<<"Done.\n";
return 0;
}

int fill_array(double ar[],int limit)
  {
double temp;
int i;
 /**//* 可以使用循環連續地將值讀入到數組中,但如何提早結束循環呢?一種方法使,使用一個特殊值來指出輸入結束。
* 由于所有的屬性都不為負,因此可以使用復述來指出輸入結束。另外,該函數應對錯誤輸入做出反應,如停止輸入等。
*/
for(i=0;i<limit;i++)
 {
cout<<"Enter value #"<<(i+1)<<":";
cin>>temp;
if(!cin) //bad input
 {
cin.clear();
while(cin.get()!='\n')
continue;
cout<<"Bad input: input process terminated.\n";
break;
}
else if(temp<0) //signale to terminate
break;
ar[i] =temp;
}
return i;
}

// the following function can use, but not alter,
// the array whose address is ar
 /**//* 要確保顯示函數不修改原始數組。除非函數的目的就是修改傳遞給它的數據,
* 否則應避免發生這種情況。使用普通參數時,這種保護將自動實現,這是由
* 于C++按值傳遞給它的書籍,而且函數使用數據的拷貝。不過,接受數組名的
* 函數將使用原始數據,這正是fill_array()函數能夠完成其工作的原因。
*/
void show_array(const double ar[], int n)
  {
 /**//* 注意,const并不是意味著原始數組必須是常量,而只是意味著不能在
* show_array()函數中使用ar來修改這些數據。因此,show_array()將數組
* 視為只讀數據。C++將聲明const double ar []解釋為const double *ar,
* 實際上是說,ar指向的是一個常量值。
*/
for(int i=0;i<n;i++)
 {
cout<<"Property #"<<(i+1)<<": $";
cout<<ar[i]<<endl;
}
}

// multiplies each element of ar[] by r
void revalue(double r,double ar[], int n)
  {
for(int i=0;i<n;i++)
ar[i]*=r;
}
第四個程序:
#include "stdafx.h"
#include <iostream>
using namespace std;
const int ArSize=8;
int sum_arr(const int *begin,const int *end);
int main(int argc, char* argv[])
  {
 int cookies[ArSize]= {1,2,4,8,16,32,64,128};
int sum=sum_arr(cookies,cookies+ArSize);

cout<<"Total cookies eaten: "<<sum<<std::endl;
sum=sum_arr(cookies,cookies+3); //first 3 elements
cout<<"First three eaters ate "<<sum<<" cookies.\n";
sum=sum_arr(cookies+4,cookies+8);//last 4 elements
cout<<"Last four eaters ate "<<sum<<" cookies.\n";
return 0;
}

int sum_arr(const int *begin,const int * end)
  {
//注意,根據指針減法規則,表達式end-begin是一個整數值,等于數組的元素數目。
const int * pt;
int total=0;
for(pt=begin;pt!=end;pt++)
total=total+*pt;
return total;
}
|