我在c的情况下假设我有下面的代码:
#include <stdio.h>
main()
{
int size=8;
int data[18]={12,9,1,7,4,5,3,11};
int i,newS;
printf("check1 \n");
newS= size+1;
data[newS]=data[0] +data[1];
printf("news %d \n",data[newS]);
printf("check2 \n");
for(i=0;i<21;i++)
{
if (data[i] <data[newS] )
{
printf("check3 \n");
data[newS+1]= data[newS] +data[i] ;
newS++;
}
else
{
printf("check4 \n");
}
}
for(i=0;i<21;i++)
{
printf("%d ",data[i]);
}
printf("\n");
}
我希望它能产生如下结果:1 2 9 1 7 4 5 3 11 21 33 42 43 50 54 59 62 73 18 18 8
。 但我不知道为什么它在“11”之后只有一个“0”。如何删除这个零?
相应代码获得的输出是这个(不是预期的):
12 9 1 7 4 5 3 11 0 21 33 42 43 50 54 59 62 73 18 18 8
答案 0 :(得分:3)
以下是我解决零问题的解决方案:(以下是任何用户未来参考的代码)。
#include <stdio.h>
main()
{
int size=8;
int data[18]={12,9,1,7,4,5,3,11};
int i,newS;
printf("check1 \n");
newS= size;
data[newS]=data[0] +data[1];
printf("news %d \n",data[newS]);
printf("check2 \n");
for(i=0;i<21;i++)
{
if (data[i] <data[newS] )
{
printf("check3 \n");
data[newS+1]= data[newS] +data[i] ;
//break;
newS++;
}
else
{
printf("check4 \n");
}
}
for(i=0;i<21;i++)
{
printf("%d ",data[i]);
}
printf("\n");
}
答案 1 :(得分:2)
1)问题的主题不断变化。这无疑令人沮丧。如果你有两个问题,要么两个都要表达,要么将它们分成两个单独的帖子。
2)提示:8值数组的最后一个元素的索引是什么?
3)对于delection - 恢复我的原始答案 - 将所有较高索引值向下移动数组中的一个空格,并将长度减少一个。