永发信息网

编程题求算法

答案:2  悬赏:40  手机版
解决时间 2021-04-28 01:11

有一带头结点的单链表L={a1,b1,a2,b2,a3,b3,.......an,bn},设计算法将其拆成两个带头结点的单链表L1和L2,L1={a1,a2...an},L2={bn,bn-1,......b1},要求L1使用L的头结点

最佳答案
递归做为一种算法在程序设计语言中广泛应用.是指函数/过程/子程序在运行过程中直接或间接调用自身而产生的重入现象.递归是计算机科学的一个重要概念,递归的方法是程序设计中有效的方法,采用递归编写程序能使程序变得简洁和清晰.。 递归是一种重要的编程技术。该方法用于让一个函数从其内部调用其自身。一个示例就是计算阶乘。0 的阶乘被特别地定义为 1。 更大数的阶乘是通过计算 1 * 2 * ...来求得的,每次增加 1,直至达到要计算其阶乘的那个数。下面的段落是用文字定义的计算阶乘的一个函数。“如果这个数小于零,则拒绝接收。如果不是一个整数,则将其向下舍入为相邻的整数。如果这个数为 0,则其阶乘为 1。如果这个数大于 0,则将其与相邻较小的数的阶乘相乘。”要计算任何大于 0 的数的阶乘,至少需要计算一个其他数的阶乘。用来实现这个功能的函数就是已经位于其中的函数;该函数在执行当前的这个数之前,必须调用它本身来计算相邻的较小数的阶乘。这就是一个递归示例。递归和迭代(循环)是密切相关的 — 能用递归处理的算法也都可以采用迭代,反之亦然。确定的算法通常可以用几种方法实现,您只需选择最自然贴切的方法,或者您觉得用起来最轻松的一种即可。显然,这样有可能会出现问题。可以很容易地创建一个递归函数,但该函数不能得到一个确定的结果,并且不能达到一个终点。这样的递归将导致计算机执行一个“无限”循环。下面就是一个示例:在计算阶乘的文字描述中遗漏了第一条规则(对负数的处理) ,并试图计算任何负数的阶乘。这将导致失败,因为按顺序计算 -24 的阶乘时,首先不得不计算 -25 的阶乘;然而这样又不得不计算 -26 的阶乘;如此继续。很明显,这样永远也不会到达一个终止点。因此在设计递归函数时应特别仔细。如果怀疑其中存在着无限递归的可能,则可以让该函数记录它调用自身的次数。如果该函数调用自身的次数太多,即使您已决定了它应调用多少次,就自动退出。下面仍然是阶乘函数,这次是用 JScript 代码编写的。 // 计算阶乘的函数。如果传递了// 无效的数值(例如小于零),// 将返回 -1,表明发生了错误。若数值有效,// 把数值转换为最相近的整数,并// 返回阶乘。function factorial(aNumber) if (aNumber == 0) else return (aNumber * factorial(aNumber - 1)); // 否则,递归直至完成。}
全部回答

L={a1,b1,a2,b2,a3,b3,.......an,bn},

Arraylist  str1=new Arraylist();

Arraylist  str2=new Arraylist();

 for(int i=0;i<L.length;i++)

{

if(i%2==0)

{

 str1.add(L[i]);

}

else

{

str2.Add(L[i]);

}

}

我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
光驱不读杀毒软件盘。
哈尔滨天香阁文化传播有限公司在哪里啊,我有
怎么样点亮CF图标
进去密码忘记了怎么办
打工仔和老板哪个跟舒服!
经济学基础计算题。设某企业有资金10万元,资
at XX:XX Shutdown -s为什么无法运行??
诺基亚N85行货能待机多久?
帮我看看这张显卡应该用什么型号驱动?谢谢
多伦县腾益龙泽酒业经销处地址在什么地方,想
想在淘宝开一个网店!卖什么好呢
从广州去江苏省泰州市怎么走?
为什么我来月经,肚子不疼呢!
5233接不到联通发的短信
有没有人觉得星际2做的有点Q版,没有了那种星
推荐资讯
电梯怎么用??封闭式的.
谁懂自考啊,我想报名,但不知道具体怎么弄?
炫舞有最高级嘛
那种向上冲的男士短发叫什么名字
wlk补丁安装问题
注销QQ最快的方法是什么?
沈阳三氏实业有限公司在什么地方啊,我要过去
求《lovely day》的歌词?
描写北方雪的唐诗,关于雪的古诗
寨西店站这个地址在什么地方,我要处理点事
河南理工大学高职学院的新校区怎么样?
还不到三十岁,因为年少时的**习惯造成现在有
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?