题目转自南邮编程在线:njupt.housecode.cc
从键盘输入整型一维数组中a中的各元素(以元素0结束,0是最后一个有效果元素,元素个数不超过20个),再输入一个待删除的整数。先输出删除前的所有数组元素。从数组中删除所有的元素值等于该整数的元素,如果元素不存在,则输出提示信息:does not exist,no operating! 否则输出删除后的所有数组元素
说明:(1)数组的定义:int a[20];
(2)应该用一个变量存储实际有效果的元素个数(含0)
(3)元素的输出用%5d的格式控制
(4)scanf之前不能用printf输出提示信息
测试用例:输入 | 测试用例:输出 |
2 3 4 5 3 2 0< 回车 > 4< 回车 > | Before delete,elements are: 2 3 4 5 3 2 0 After delete,elements are: 2 3 5 3 2 0 |
2 3 4 2 0< 回车 > 5< 回车 > | Before delete,elements are: 2 3 4 2 0 does not exist,no operating! |
2 3 3 4 3 5 3 7 0< 回车 > 3< 回车 >
| Before delete,elements are: 2 3 3 4 3 5 3 7 0 After delete,elements are: 2 4 5 7 0 |
代码如下:
#include <stdio.h>
int main()
{
int a[20];
int i, j, n, count;
for (i = 0; i < 20; ++i) {
scanf("%d", &a[i]);
if (a[i] == 0) {
break; //break会跳过++i
}
}
count = i+1;
int k = count;
scanf("%d", &n);
printf("Before delete,elements are:\n");
for (i = 0; i < count; ++i) {
printf("%5d", a[i]);
}
printf("\n");
i = 0;
while(i < count) {
if (a[i] == n) {
count--;
for (j = i; j < count; ++j) {
a[j] = a[j+1];
}
}
else {
i++;
}
}
if (i == k) {
printf("does not exist,no operating!");
}
else {
printf("After delete,elements are:\n");
for (i = 0; i < count; ++i) {
printf("%5d", a[i]);
}
}
return 0;
}
此题考查的数组的遍历,是一个简单的数组题,注意一下break语句跳出循环时是直接从当前位置跳出,不会执行for语句中的++i