数组排序问题

举报
悦来客栈的老板 发表于 2020/12/30 01:14:23 2020/12/30
【摘要】 有一个整型数组int A[nSize],其中隐藏着若干0,其余非0整数,写一个函数int Func(int* A, int nSize), 使A把0移至后面,非0整数移至数组前面并保持有序(保持原来的顺序),返回值为原数据中第一个元素为0的下标。 #include <stdio.h> int Func(int *a, int nSize){ int...

使A把0移至后面,非0整数移至数组前面并保持有序(保持原来的顺序),返回值为原数据中第一个元素为0的下标。



  
  1. #include <stdio.h>
  2. int Func(int *a, int nSize)
  3. {
  4. int i,k,t=1,flag = 0;
  5. for (i=0; i<nSize-1;i++)
  6. {
  7. if (a[i] == 0 && flag == 0)
  8. {
  9. k = i;
  10. }
  11. if (a[i] == 0 && a[i+1] != 0)
  12. {
  13. a[i+1-t] = a[i+1]; //隔了多少个0
  14. a[i+1] = 0;
  15. }
  16. else if (a[i] == 0 && a[i+1] == 0)
  17. {
  18. t++;
  19. }
  20. }
  21. return k;
  22. }
  23. int main()
  24. {
  25. int i;
  26. int a[] = {1,2,3,0,4,5,0,6,0,0,0,0,0,0,0,1,5,4,1,22,-65,1545,0,0,0,54,12,35};
  27. for (i=0; i<sizeof(a)/sizeof(a[0]);i++)
  28. {
  29. printf("%d ",a[i]);
  30. }
  31. printf("\n");
  32. Func(a,sizeof(a)/sizeof(a[0]));
  33. for (i=0; i<sizeof(a)/sizeof(a[0]);i++)
  34. {
  35. printf("%d ",a[i]);
  36. }
  37. printf("\n");
  38. return 0;
  39. }


文章来源: blog.csdn.net,作者:悦来客栈的老板,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/qq523176585/article/details/11784467

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。