解题思路:
利用指针对数组进行数据重组,可以很方便的完成删除数组中的元素。
注意事项:
参考代码:
#include<stdio.h> int CompactIntegers(int *arr,int n) { int *t=arr; //目标指针先指向数组头 int num=0; while(n--) //遍历数组 { if(*arr!=0) { *t++=*arr; //如果当前元素不是要删除的,则保存到目标数组中 num++; //记录保存元素的个数 } arr++; //检查下一个元素 } return num; } int main() { int n,arr[100]; int i,t; scanf("%d",&n); for(i=0;i<n;i++) { scanf("%d",&arr[i]); } t=CompactIntegers(arr,n); for(i=0;i<t;i++) { printf("%d ",arr[i]); } printf("\n%d",t); }
0.0分
0 人评分
震宇大神的杀毒软件 (C++代码)浏览:1118 |
C语言训练-求素数问题 (C语言代码)浏览:728 |
P1002 (C语言代码)浏览:980 |
C语言训练-计算t=1+1/2+1/3+...+1/n (C语言代码)浏览:908 |
用筛法求之N内的素数。 (C语言代码)浏览:808 |
IP判断 (C语言代码)浏览:764 |
【求[X,Y]内被除3余1并且被除5余3的整数的和】 (C语言代码)浏览:675 |
用筛法求之N内的素数。 (C语言代码)浏览:669 |
Tom数 (C语言代码)浏览:555 |
1052题解(链表操作)浏览:674 |