Algo79 Java 算法训练 删除数组零元素

//入门小白,看了很多别人的想法,这里,在实践后表达自己的想法,对这题来说应该是最够相近了。
//全文分四大块:题目,理解,代码,得分。

题目
从键盘读入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

理解
1.题目要求有一个CompactIntegers(数组,元素个数)函数,return 删除0元素后数组的大小。
2.既然有了该函数,这里可不用动态数组ArrayList,静态数组就可以,且动态数组可能耗用更多的cpu。
3.该函数返回的是数组大小,输出中“元素个数+数组除开0的元素”。所以在CompactIntegers函数中只用计算除开0的元素个数,main中输出结果时判断非零输出就可。不用真正意义上从数组删除0元素,只是不输出0就可。

代码
Algo79 Java 算法训练 删除数组零元素
得分
Algo79 Java 算法训练 删除数组零元素
加油哦!