文章目录
1、下面定义数组的语句正确的是?
(a) int i=6;char a[i]= “hello ”;
(b) const int i=5;char a[i]= “hello ”;
(c) char a[6]= ”hello ” ;
(d) char a5= ”hello ”;
解析:
数组定义中数组长度不能指定为除 const 变量以外的变量,选项 a 中 i 为变量;
选项 b 中字符串“ hello ”含有 6 个字符,而数组 a 的长度是 5 所以编译器报错;
选项 d 中 a5 是一个字符变量而不是字符数组,而“ hello ”含有 6 个字符,无法放在一个字符变量中。
2、已知数组 a 定义为: int a[][3]={{1,2,3},{4}}; , 则 a[1][2] 的值为?
(a)2 (b)3 ( c)4 (d)0
解析:在对数组进行初始化时只给出部分元素的初始值,则剩余元素自动初始化为 0。
3、已知数组定义为 int a[2][4]; ,下列对数组元素引用正确的为?
(a)a[1,2] (b)a[1][2] ( c)a(1,2) (d)a[1][4]
4、下列程序段错误的是?
(a) char str1[8];
cin>>str1;
(b) char str1[8];
strcpy(str1, ” first ”);
( c) char str1[8];
for(int i=0;i<7;i++)
cin>>str1[i];
str1[7]= ’\0 ’ ;
(d) char str1[8],str2[8]= ”first ”;
str1=str2;
解析:为字符数组赋值可以直接从键盘输入一个字符串、用 strcpy 函数将一个字符串复制到该字符数组或者用循环语句逐个为字符数组元素赋值。不能直接将一个数组赋值给另一个数组。
5、下列说法正确的是?
(a) 数组可以存放不同类型的元素。
(b) 定义 int a[2];, 则数组 a 有两个数组元素。
(c ) 定义 int a[3];, 则该数组中元素分别为: a[0],a[1],a[2],a[3] 。
(d) 在编译时,不必确定数组的大小。
6、运行下列程序结果为?
#include<bits/stdc++.h>
using namespace std;
void main()
{
int array1[3][3] = { {1,2,13},{4,5,16},{7,8,9} }, i = 0, j = 2, sum1 = 0, sum2 = 0;
for (; i < 3; i++)
{
sum1 += array1[i][i];
sum2 += array1[i][j--];
}
cout << sum1 << setw(10) << sum2 << endl;
}
解答:
7、请编写程序实现:检查字符串 s 中是否包含字符串 t ,若包含,则返回并输出 t 在 s 中的开始位置(下标值) ,否则返回 -1 。
解答:
//请编写程序实现:检查字符串 s 中是否包含字符串 t ,
//若包含,则返回并输出 t 在 s 中的开始位置(下标值) ,否则返回 -1 。
#include<bits/stdc++.h>
using namespace std;
int main()
{
int i, j, k;
char s[20] = "Today is sunday!", t[10] = "sun";
for (i = 0; s[i] != '\0'; i++)
{
for (j = i, k = 0; t[k] != '\0' && s[j] == t[k]; j++, k++);
if (t[k] == '\0')
{
cout << "t 在 s 中的开始位置下标为 :" << i << endl;
return i;
}
}
return -1;
}
8、编程实现任意输入 10 个数,然后按从小到大的顺序输出这 10 个数。
//编程实现任意输入 10 个数,然后按从小到大的顺序输出这 10 个数。
#include<bits/stdc++.h>
using namespace std;
int main()
{
int a[10], i, j, temp;
cout << "请输入10个数:";
for (i = 0; i <= 9; i++)
{
cin >> a[i];
}
for (i = 0; i < 9; i++) // 排序
{
for (j = i + 1; j < 10; j++)
if (a[j] < a[i])
{
temp = a[i];
a[i] = a[j];
a[j] = temp;
}
}
for (i = 0; i < 10; i++) cout << setw(5) << a[i];
cout << endl;
return 0;
}
9、选择题
(1)在 C++中对数组下标说法正确的是?
(a) 初始化数组的值的个数可以多于定义的数组元素的个数,多出部分将被忽略。
(b) 初始化数组的值的个数可以少于定义的数组元素的个数。
( c) 初始化数组的值的个数必须等于定义的数组元素的个数。
(d) 初始化数组的值可以通过跳过逗号的方式来省略。如 int a[3]={1,2};
(2) 数组定义为 :int a[2][2]={1,2,3,4}; 则 a[1][0]%3 为?
(a)0 (b)1 ( c)2 (d)4
(3)数组定义为: int a[][2]={5,6,1,2,3,8}; 则能用于计算数组下标的是?
(a)sizeof(a)/sizeof(int) (b)sizeof(a[])/sizeof(3)
( c)sizeof(a[][2])/sizeof(int) (d)sizeof(a)/sizeof(a[2][1])
(4)运行下列程序结果为( )。
#include<bits/stdc++.h>
using namespace std;
void main()
{
int a[4]={1,2,3,4};
for(int i=3;i>=0;i--)
cout<<a[i];
}
(a)1234 (b)1324 ©4231 (d)4321
(5) 运行下列程序结果为( )。
#include<bits/stdc++.h>
using namespace std;
void main()
{
int i,j,t,a[2][2]={8,7,6,5};
for(i=0;i<1;i++)
for(j=i+1;j<2;j++)
{
t=a[i][j];
a[i][j]=a[j][i];
a[j][i]=t;
409--52
}
for(i=0;i<2;i++)
{
for(j=0;j<2;j++)
cout<<a[i][j];
cout<<endl;
}
}
(a)87 65 (b)78 65 ©86 75 (d)68 57
10、填空题
(1) mxn数组包含m行、n列和 mxn个元素。
(2)定义数组 int a[10]; ,若要给该数组的第三个元素赋值 100,其语句为 a[2]=100;。
(3) 请编写程序实现:已知数组 a 中的元素个数为 4,下列语句的作用是将下标为 i 的元素移动到下标为 i-1 的单元,其中 1≤i<4。a 中原有数据为 1,2,3,4,移动后 a 中元素结果为 2,3,4,4。
解答:
#include <bits/stdc++.h>
using namespace std;
void main()
{
int a[4] = { 1,2,3,4 };
for (int i = 0; i < 3; i++)
a[i] = a[i+1];
}
(4)编写程序实现:当 str 是对称的时,输出“是回文”,否则输出“不是回文。
解答:
#include <bits/stdc++.h>
using namespace std;
void main()
{
char str[20];
cin.get(str, 20);// 输入字符串
int i = 0, j = 0;
while (str[j])j++;
for (j--; i < j && str[i] == str[j]; i++, j--);
if (i==j) cout << " 是回文 ";
else cout << " 不是回文 ";
}
(5)运行下列程序的结果为?
#include <bits/stdc++.h>
using namespace std;
void main()
{
int array1[3][3] = { 1,2,3,4,5,6,7,8,9 }, array2[3][3], i, j;
for (i = 0; i < 3; i++)
for (j = 0; j < 3; j++)
array2[j][i] = array1[i][j];
for (i = 0; i < 3; i++)
{
for (j = 0; j < 3; j++)
cout << setw(3) << array2[i][j];
cout << endl;
}
}
解答:
(6)运行下列程序的结果为?
#include<bits/stdc++.h>
using namespace std;
void main()
{
int num[6],i,j;
cout<<" 请输入 1 到 50 的六个正整数: ";
for(i=0;i<6;i++)
cin>>num[i];
for(i=0;i<6;i++)
{
for(j=1;j<=num[i];j++)
cout<<"*";
cout<<endl;
}
}
输入为: 2 4 1 6 3 1
解答:
11、编程题
(1)编写一个程序实现矩阵的乘法运算。
#include <bits/stdc++.h>
using namespace std;
void main()
{
const int A1 = 2, A2 = 3, A3 = 2;
int i, j, k;
double array1[A1][A2] = { {1.0,2.0,3.0},{4.0,5.0,6.0} },
array2[A2][A3] = { {1.0,1.0},{1.0,1.0},{1.0,1.0} },
array3[A1][A3] = { 0,0,0,0 };
for (i = 0; i < A1; i++)
for (j = 0; j < A3; j++)
for (k = 0; k < A2; k++)
array3[i][j] += array1[i][k] * array2[k][j];
for (i = 0; i < A1; i++)
{
for (j = 0; j < A3; j++)
cout << setw(4) << array3[i][j];
cout << endl;
}
}
(2) 输入一个 4×4 矩阵各元素的值,求解该矩阵中的马鞍点(即该点的值在它所在的行中最大,在它所在的列中最小) 。
#include <bits/stdc++.h>
using namespace std;
void main()
{
int array[4][4], i, j, k, max, col, flag = 0;
cout << " 请输入 4 行 4 列矩阵: ";
for (i = 0; i < 4; i++)
for (j = 0; j < 4; j++)
cin >> array[i][j];
for (i = 0; i < 4; i++)
{
max = array[i][0]; col = 0;
for (j = 1; j < 4; j++)
{
if (array[i][j] > max)
{
max = array[i][j];
col = j;
}
}
for (k = 0; k < 4; k++)
{
if (array[k][col] <= max && k != i)
break;
}
if (k == 4)
{
cout << "马鞍点在 " << i << "行" << col << "列:" << array[i][col];
flag = 1;
}
}
if (!flag)
cout << " 这个矩阵中没有马鞍点! ";
}
(3)写统计输入的正文中有多少单词的程序,这里的单词指的是用空白符分隔开的字符串。
#include <bits/stdc++.h>
using namespace std;
void main()
{
const int MAX = 100;
char str[MAX];
int i, num = 0;
cin.get(str, 100);// 输入字符串,以回车结束
for (i = 0; i < MAX && str[i] != '\0'; i++)
{
if (str[i] == ' ')
num++;
}
if (num != 0)num++;
cout << " 单词数为: " << num << endl;
}
(4) 编写程序实现一个简单的加密器,实现英文字符串的加密。加密规则如下:将字符替换成它后面的第三个字符。如” abc”换成” def ”。
#include <bits/stdc++.h>
using namespace std;
void main()
{
const int LENGTH = 100;
char str[LENGTH];
cout << " 请输入字符串 :";
cin >> str;
for (int i = 0; i < LENGTH; i++)
{
if (str[i] == '\0') break;
str[i] = str[i] + 3;
}
cout << " 加密后的字符串为: " << str << endl;
}
(5)编写一程序,将字符数组 s2 中的全部字符拷贝到字符数组 s1 中。不用 strcpy 函数。拷贝时, ’0’也要拷贝过去。 ’0’后面的字符不拷贝。
#include <bits/stdc++.h>
using namespace std;
void main()
{
int i, j, len1 = 0, len2 = 0;
char s1[20] = "hello ", s2[10] = "world";
for (i = 0; i < 20; i++)
if (s1[i] != '\0') len1++;
else break;
for (i = 0; i < 10; i++)
if (s2[i] != '\0') len2++;
else break;
if ((len1 + len2) > 19)
{
cout << " 存储空间不足 !";
return;
}
i = len1;
j = 0;
while (i < 20 && s2[j] != '\0')
s1[i++] = s2[j++];
s1[i] = '\0';
cout << s1 << endl;
}
(6) 有 17 个人围成一个圈 ( 编号 0-16) ,从第 0 号的人开始从 1 报数,凡报到 3 的倍数的人离开圈子,然后再继续数下去。直到最后只剩下一个人为止。问此人原来的位置是多少号?
#include <bits/stdc++.h>
using namespace std;
void main()
{
int array[17], n = 17, i, j = 1;
for (i = 0; i < 17; i++)
array[i] = 1;
i = 1;
while (n != 1)
{
if (array[(j - 1) % 17] == 0)
{
j++; continue;
}
if (i % 3 == 0)
{
array[(j - 1) % 17] = 0;
n--;
}
j++; i++;
}
for (i = 0; i < 17; i++)
{
if (array[i] == 1) cout << " 最后一个人原来的位置(下标)是 :" << i << endl;
}
}
(7) 给定一个升序数组,该数组的元素值为 1,3,5,7, 9,11,13,任意输入一个数判断该数在数组中是否存在。若存在,给出它在数组中的位置,否则显示该数不存在。
#include <bits/stdc++.h>
using namespace std;
void main()
{
int array[7] = { 1,3,5,7,9,11,13 }, x, low = 0, high = 6, mid, flag = 0;
cout << " 请输入待查找的数: " << endl;
cin >> x;
while (low <= high)
{
mid = (high + low) / 2;
if (x == array[mid])
{
cout << " 找到了,该数的下标为: " << mid << endl;
flag = 1;
break;
}
else
if (x < array[mid]) high = mid - 1;
else low = mid + 1;
}
if (!flag)
cout << " 该数不存在! " << endl;
}
(8) 打印输出杨辉三角形(共输出 10 行)。
#include <bits/stdc++.h>
using namespace std;
void main()
{
const int ROW = 10;
const int COL = 10;
int yh[ROW][COL], row, col;
for (row = 0; row < ROW; row++)
{
yh[row][0] = 1; yh[row][row] = 1;
}
for (row = 2; row < ROW; row++)
{
for (col = 1; col < row; col++)
{
yh[row][col] = yh[row - 1][col - 1] + yh[row - 1][col];
}
}
for (row = 0; row < ROW; row++)
{
for (col = 0; col <= row; col++)
cout << setw(5) << yh[row][col];
cout << endl;
}
}