写出这个代码解决这个问题,虽然不是写的简洁明了肯定有比这更简单的方法,但也吧学习到的知识运用到了,能够复习加深印象,巩固学习成果,这个代码也是用了很长时间的,刚开始打算用一个循环解决问题的,可惜学习不到位没写出来,就很尴尬。主函数中主要完成的是输入和打印,没什么可说的,在33行这个代码中因为传过去的是数组首元素地址,所以在实现这个函数的时候用的是指针类型接受的,这段代码解决问题的核心就在这个函数里了,首先外层循环控制的是交换的次数当为0时进行第一遍交换,为1时进行第二遍交换……这样以此类推直到判断条件不成立,循环结束。内层循环控制的是数值是否需要交换,根据题目要求0要置后且位置顺序不变,由十五行代码为判断条件,如果为0的话就和后面的数值进行交换这样就能保证每一次循环过后,如果数组内有0的话最后一位会被0取代,其他数值都往前移一位,同样第一位肯定不是0了,除非数组内都是0.所以在十三行的判断中减去了 i 因为这时已经确定在不全为0的条件下,一次循环过后它的位置不是0,所以下次交换时就可以从他后面的数值进行判断交换了,这样可以提高效率,减一是因为,如果两两进行交换的话,像六个元素的话只需要交换五次就行了。
数组元素的处理
最新推荐文章于 2024-07-10 17:41:33 发布