解题思路:
利用指针对数组进行数据重组,可以很方便的完成删除数组中的元素。
注意事项:
参考代码:
#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语言训练-斐波纳契数列 (C语言代码)浏览:813 |
C语言程序设计教程(第三版)课后习题3.7 (C++代码)浏览:1018 |
C语言训练-排序问题<1> (C语言代码)浏览:1368 |
数列 (C++代码)浏览:677 |
震宇大神的杀毒软件 (C语言代码)浏览:1297 |
C语言程序设计教程(第三版)课后习题6.3 (C语言代码)浏览:529 |
C语言训练-列出最简真分数序列* (C语言代码)浏览:638 |
1009题解浏览:762 |
1012题解浏览:899 |
程序员的表白 (C语言代码)浏览:611 |