您的位置:首页 > 编程语言 > C语言/C++

返回一个数组中所有元素被第一个元素除的结果

2016-12-18 19:17 323 查看
这是朋友问的题,先贴出题中给的代码:

void DivArray(int *pArray,int n)
{
int i;
for (i = 0; i < n; i++) {
pArray[i] /= pArray[0];
}
}
恩,第一眼一看是挺简单的,于是,敲出代码:

#include<stdio.h>
void DivArray(int *pArray, int n);
int main()
{
int a[] = { 2,4,6,8,10,12,14 },i;
DivArray(a,7);
for (i = 0; i < sizeof(a) / sizeof(a[0]); i++) {
printf("%d ",a[i]);
}
return 0;
}
void DivArray(int *pArray,int n)
{
int i;
for (i = 0; i < n; i++) {
pArray[i] /= pArray[0];
}
}
虽然看上去很简单,但是,输出亮了:

1 4 6 8 10 12 14    请按任意键继续. . .

观察结果,除了第一个元素被除了以外,其他的都是原来的值,不用想,愿意肯定在操作函数里面,观察这个循环,循环是从零开始的,这是普遍的人的一个误区,很多人一般敲代码都是喜欢把循环的范围从0开始,而事实也是大多数时候循环的范围从0开始。。。

分析一下循环:首先从i=0开始,于是就有 pArray[0] /= pArray[0]; 好吧,第一个元素的值变为1了,不用看了,后面的除以1还是本事,所以问题就在于这里的循环范围,由于数组后面的元素还需要用0号元素对其自身操作,如果0号元素的值改变了,那么结果基本上就错了,虽然这个看似一个小问题,但是还是值得我们深思的,类似的问题还有很多,例如,我们对数组操作,并且保存数组的索引,而且要对索引进行操作的情况,这个时候就不能只用一个变量来保存索引。。。不然,在此处操作了数组的索引,下次对数组操作时,就可能出现索引指向错误,或者数组越界等等问题。。。

好吧,回到正题,综上所述呢,我们只需要把循环的范围改变一下就好了,将循环的i的初始值赋0改成赋1就好,最后加一句pArray[0] /= pArray[0];

好了,贴代码了:

#include<stdio.h>
void DivArray(int *pArray, int n);
int main()
{
int a[] = { 2,4,6,8,10,12,14 },i;
DivArray(a, sizeof(a) / sizeof(a[0]));
for (i = 0; i < sizeof(a) / sizeof(a[0]); i++) {
printf("%d ",a[i]);
}
return 0;
}
void DivArray(int *pArray,int n)
{
int i;
for (i = 1; i < n; i++) {
pArray[i] /= pArray[0];
}
pArray[0] /= pArray[0];
}
你以为就这么完了?呵呵,天真,要是我的0号元素的值为0怎么办,要是我的指针为空怎么办?所以还应该加语句判断程序才稳定。
#include<stdio.h>
void DivArray(int *pArray, int n);
int main()
{
int a[] = { 2,4,6,8,10,12,14 },i;
DivArray(a, sizeof(a) / sizeof(a[0]));
for (i = 0; i < sizeof(a) / sizeof(a[0]); i++) {
printf("%d ",a[i]);
}
return 0;
}
void DivArray(int *pArray,int n)
{
if (!pArray || !pArray[0])
return;
int i;
for (i = 1; i < n; i++) {
pArray[i] /= pArray[0];
}
pArray[0] /= pArray[0];
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  c语言
相关文章推荐