1452|0

3836

帖子

19

TA的资源

纯净的硅(中级)

楼主
 

编程写一个函数int Func的实例 [复制链接]

(2)int A[nSize],其中隐藏着若干0,其余非0整数,写一个函数int Func(int* A, int nSize),使A把0移至后面,非0整数移至数组前面并保持有序,返回值为原数据中第一个元素为0的下标。(尽可能不使用辅助空间且考虑效率及异常问题,注释规范且给出设计思路)
#include "stdafx.h"
#include
using namespace std;
int Func(int *A, int nSize)
{
if (NULL == A || nSize <= 0)
{
return -1;
}
int count = 0;
int pos = -1;
for (int i = 0; i < nSize; i++)
{
if (-1 == pos && A[i] == 0)
{
pos = i;
count++;
}
else if (A[i] == 0)
{
count++;
}
else
{
for (int j = 0; j < count; j++)
{
A[i - j - 1] = A[i - j];
}
}
}
for (int i = count; i > 0; i--)
{
A[nSize - i] = 0;
}
return pos;
}

int _tmain(int argc, _TCHAR* argv[])
{
int A[] = {6 ,0 ,3, 4, 0, 5, 9, 6, 4, 6, 5, 8, 0, 0};
int nSize = sizeof(A)/sizeof(A[0]);
cout<<"before: ";
for (int i = 0; i < nSize; i++)
{
cout< }
int pos = Func(A, nSize);
cout< for (int i = 0; i < nSize; i++)
{
cout< }
cout< cout< system("pause");
return 0;
}

 
点赞 关注

回复
举报
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

关闭
站长推荐上一条 1/10 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表