#include
#include
#include
#include
using namespace std;
template
T largest_element(const T *array,int num1)
{
T max = array[0] ;
for(int i = 0; i != num1; ++i)
{
if(max < array[i])
max = array[i] ;
}
return max ;
}
int main()
{
int num2 = 0, flag;
cout << "1.输入int型数组\n2.输入double型数组\n3.输入char型数组"
"\n4.输入string型数组\n输入0退出\n" ;
while(cin >> flag)
{
if(flag == 1)
{
cout << "输入int型数组\n" ;
int arr[] = {0} ;
cout << "输入数组格式: " ;
cin >> num2 ;
for(int i = 0; i != num2; ++i)
{
cout << "输入" << i+1 << '.' ;
cin >> arr[i] ;
}
cout << largest_element(arr,num2) << endl ;
break;
}
if(flag == 2)
{
cout << "输入double型数组\n" ;
double arr[] = {0} ;
cout << "输入数组格式: " ;
cin >> num2 ;
for(int i = 0; i != num2; ++i)
{
cout << "输入" << i+1 << '.' ;
cin >> arr[i] ;
}
cout << largest_element(arr,num2) << endl ;
break;
}
if(flag == 3)
{
cout << "输入char型数组\n" ;
char arr[] = {0} ;
cout << "输入数组格式: " ;
cin >> num2 ;
for(int i = 0; i != num2; ++i)
{
cout << "输入" << i+1 << '.' ;
cin >> arr[i] ;
}
cout << largest_element(arr,num2) << endl ;
break;
}
if(flag == 4)
{
cout << "输入string型数组\n" ;
string *arr;
cout << "输入数组格式: " ;
cin >> num2 ;
arr = new string[num2] ;
for(int i = 0; i != num2; ++i)
{
cout << "输入" << i+1 << '.' ;
cin >> arr[i] ;
}
cout << largest_element(arr,num2) << endl ;
delete[] arr ;
break;
}
if(flag == 0)
{
exit(0) ;
}
}
return 0;
}
你这样分配数组的方式都是有问题的。
double arr[] = {0} ;这样意味着数组大小是1,输入一个以上就越界了,结果就不好说了。
1.如果是G++编译器可以使用变量数组
cin >> num2 ;
double arr[num2] = {0} ;
2.如果是别的编译器,就用new动态分配
cin >> num2 ;
double *arr = new double[num2] ;
3.也可以将数组大小开的大一点
double arr[50] = {0} ;
字长和寻址范围毫无关系。
地址线宽度和寻址范围才有关。
比如Intel 80286/80386 sx是16位计算机,但是因为有24条地址线,所以可以寻址到16MB,而不是64K(2^16)
Intel Pentium III Xeon是32位计算机,但是因为有36条地址线,可以寻址64GB而不是32GB(2^32)
0 0 评论 0 |