删除声明静态不工作的数组的前两个元素

时间:2014-02-05 21:29:53

标签: c arrays algorithm

我在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

2 个答案:

答案 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 - 恢复我的原始答案 - 将所有较高索引值向下移动数组中的一个空格,并将长度减少一个。