鱼C论坛

 找回密码
 立即注册
查看: 1456|回复: 5

[已解决]删除数组0元素

[复制链接]
发表于 2021-10-28 10:36:04 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
从键盘读入n个整数放入数组中,编写函数CompactIntegers,删除数组中所有值为0的元素,其后元素向数组首端移动。注意,CompactIntegers函数需要接受数组及其元素个数作为参数,函数返回值应为删除操作执行后数组的新元素个数。输出删除后数组中元素的个数并依次输出数组元素。
样例输入: (输入格式说明:5为输入数据的个数,3 4 0 0 2 是以空格隔开的5个整数)
5
3 4 0 0 2
样例输出:(输出格式说明:3为非零数据的个数,3 4 2 是以空格隔开的3个非零整数)
3
3 4 2
样例输入:
7
0 0 7 0 0 9 0
样例输出:
2
7 9
样例输入:
3
0 0 0
样例输出:
0
<#include<stdio.h>
int a[1005]={0};
int m;
int compactintegers(int c)
{
        int i,j;
        for(i=0;i<c;i++)
        {
                if(a[i]==0)
                {
                        a[i]=a[i+1];m--;
                }
        }
        return m;
}
int main()
{
        int n,i;
        scanf("%d",&n);
        for(i=0;i<n;i++)
        {
                scanf("%d",&a[i]);
        }
        m=n;
    m=compactintegers(n);
        printf("%d\n",m);
        for(i=0;i<m;i++)
        {
                printf("%d ",a[i]);
        }
        return 0;
}>
样例输出是3
3 4 0
请问哪里有问题
最佳答案
2021-10-28 11:01:43
if(a[i]==0)
{
   a[i]=a[i+1];m--;
}
问题出在这里,这里只考虑了一种情况就是0,7这样的  把7前移到0的位置  但是第一个例子的0 0 2部分就会变成0 2
提供一种思路
  1. #include<stdio.h>
  2. int a[1005] = { 0 };
  3. int m;
  4. int compactintegers(int c)
  5. {
  6.         int i, j = 0;
  7.         for (i = 0; i<c; i++)
  8.         {
  9.                 if (a[i] == 0)
  10.                 {
  11.                         m--;
  12.                 }
  13.                 else
  14.                 {
  15.                         a[j] = a[i];
  16.                         j++;
  17.                 }
  18.         }
  19.         return m;
  20. }
  21. int main()
  22. {
  23.         int n, i;
  24.         scanf("%d", &n);
  25.         for (i = 0; i<n; i++)
  26.         {
  27.                 scanf("%d", &a[i]);
  28.         }
  29.         m = n;
  30.         m = compactintegers(n);
  31.         printf("%d\n", m);
  32.         for (i = 0; i<m; i++)
  33.         {
  34.                 printf("%d ", a[i]);
  35.         }
  36.         return 0;
  37. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-10-28 11:01:43 | 显示全部楼层    本楼为最佳答案   
if(a[i]==0)
{
   a[i]=a[i+1];m--;
}
问题出在这里,这里只考虑了一种情况就是0,7这样的  把7前移到0的位置  但是第一个例子的0 0 2部分就会变成0 2
提供一种思路
  1. #include<stdio.h>
  2. int a[1005] = { 0 };
  3. int m;
  4. int compactintegers(int c)
  5. {
  6.         int i, j = 0;
  7.         for (i = 0; i<c; i++)
  8.         {
  9.                 if (a[i] == 0)
  10.                 {
  11.                         m--;
  12.                 }
  13.                 else
  14.                 {
  15.                         a[j] = a[i];
  16.                         j++;
  17.                 }
  18.         }
  19.         return m;
  20. }
  21. int main()
  22. {
  23.         int n, i;
  24.         scanf("%d", &n);
  25.         for (i = 0; i<n; i++)
  26.         {
  27.                 scanf("%d", &a[i]);
  28.         }
  29.         m = n;
  30.         m = compactintegers(n);
  31.         printf("%d\n", m);
  32.         for (i = 0; i<m; i++)
  33.         {
  34.                 printf("%d ", a[i]);
  35.         }
  36.         return 0;
  37. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-10-28 11:05:06 | 显示全部楼层
注意,CompactIntegers函数需要接受数组及其元素个数作为参数

不按照题目要求写代码,就算是输出结果正确,估计也不会得分吧
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-10-28 11:16:31 | 显示全部楼层
问题出在你返回的m只是表示了有多少个为0的值,并不能说明非零值的位置,所以直接打印前m条是不对的
参考代码



  1. #include<stdio.h>
  2. int a[1005]={0};
  3. int b[1005]={0};
  4. int m;
  5. int j=0;
  6. int compactintegers(int c)
  7. {
  8.         int i;
  9.         for(i=0;i<c;i++)
  10.         {
  11.                 if(a[i]==0)
  12.                 {
  13.                         a[i]=a[i+1];m--;
  14.                 }
  15.                 else{
  16.                               b[j] = i;
  17.                               j++;
  18.                      }
  19.         }
  20.         return m;
  21. }
  22. int main()
  23. {
  24.         int n,i;
  25.         scanf("%d",&n);
  26.         for(i=0;i<n;i++)
  27.         {
  28.                 scanf("%d",&a[i]);
  29.                
  30.         }
  31.         m=n;
  32.         m=compactintegers(n);
  33.         printf("%d\n",m);
  34.         for(i=0;i<j;i++)
  35.        {
  36.                int k=0;
  37.                k = b[i];
  38.                 printf("%d ",a[k]);
  39.        }
  40.         return 0;
  41. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-10-28 11:22:39 | 显示全部楼层
按照题目要求写代码

  1. #include <stdio.h>

  2. size_t CompactIntegers(int array[], size_t size) {
  3.     for(size_t i = 0; i < size; ++i) {
  4.         if(!array[i]) {
  5.             for(size_t j = i + 1; j < size; ++j) {
  6.                 array[j - 1] = array[j];
  7.             }
  8.             --size; --i;
  9.         }
  10.     }
  11.     return size;
  12. }

  13. int main(void) {
  14.     int array[1024];
  15.     size_t count; scanf("%lu", &count);
  16.     for(size_t i = 0; i < count; ++i) scanf("%d", &array[i]);
  17.     count = CompactIntegers(array, count);
  18.     printf("%lu\n", count);
  19.     for(size_t i = 0; i < count; ++i) printf("%d ", array[i]);
  20.     printf("\n");
  21.     return 0;
  22. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-10-28 12:08:49 | 显示全部楼层
感觉2楼最简便以及贴合我最开始的想法,容易理解,谢谢大家的解惑
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-26 00:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表