那个外企面试题目的答案(因为是我出的题目)其实很简单的!

bskay 2002-01-10 10:30:20
static int ProcessOnce(int* a, int nCount)
{
//返回“最靠近”a的数组
//如上面的 a={7,0,0}
//则返回后a为{6,1,0}
//再调用ProcessOnce后
//a为{5,2,0}
for(int n=0; n<nCount-1; n++)
{
if(a[n] > a[n+1]+2 )
{
a[n]--;
a[n+1]++;
break;
}
}
if (n == nCount-1)
return FALSE;
return TRUE;
}
static int IsCondition(int* a, int nCount)
{
for(int n=0; n<nCount; n++)
{
if (a[n] == 0)
return FALSE;
}
return TRUE;
}
void CFffApp::asst()
{
int n=100;
int m=7;
int* a = new int[m];
for(int i=0;i<m; i++) a[i] = 0;
a[0] = n;

while(ProcessOnce(a,m))
{
if(IsCondition(a,m))
{
for(int n=m-1; n>=0; n--)
{
TRACE("%d ", a[n]);
}
TRACE("\n");
}
}
}

我老是输错,真抱歉啊!!
都3次了,哎~~~~~~~~~~`
...全文
128 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
Soft21 2002-01-12
  • 打赏
  • 举报
回复
大家好啊,Up!
bskay 2002-01-10
  • 打赏
  • 举报
回复
if(a[n] > a[n+1]+2 ) 时递增为1

check 时为大于,而不是为0
bskay 2002-01-10
  • 打赏
  • 举报
回复
ProcessOnce(int* a, int nCount)
不对!取下一个?
vc7 2002-01-10
  • 打赏
  • 举报
回复
哦????
Kevin_qing 2002-01-10
  • 打赏
  • 举报
回复
嘿嘿嘿嘿~你的这个方法根本就是错的唉
看看n=9,m=3的结果

1,3,5

少了

2,3,4




bskay 2002-01-10
  • 打赏
  • 举报
回复
如果n>1+2+..+m:

for(int i=0;i<m; i++) a[i] = m-i;
a[0] = n-m*(m-1)/2;

16,473

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧