| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 484 人关注过本帖
标题:递归法数组倒置
只看楼主 加入收藏
Cking
Rank: 1
等 级:新手上路
帖 子:33
专家分:0
注 册:2007-9-23
收藏
 问题点数:0 回复次数:3 
递归法数组倒置
void invert(int a[], int k)
{
int t;
if(1);
{
invert(2);
t=a[0];
a[0]=a[k-1];
a[k-1]=t;
}
}

功能对一个数组的前K个元素进行倒置。
那1和2应该填什么?
我看了半天认为:1处是k>1;
2处是(a,k-1)
VC上没有试出来。
搜索更多相关主题的帖子: 递归 倒置 
2007-11-03 22:37
作弊
Rank: 1
等 级:新手上路
帖 子:50
专家分:0
注 册:2007-11-3
收藏
得分:0 
t=a[0];
a[0]=a[k-1];
a[k-1]=t;
错了
每次都是在替换 a[0]和k元素

=======

int k=0
invert(a, k)
{
int t
if(k<a.length/2) //调换前1/2 即可
{
invert(k+1)
t=a[k]
a[k]=a[a.length-k-1]
a[a.length-k-1]=t
}
}

未测试
2007-11-04 00:08
Cking
Rank: 1
等 级:新手上路
帖 子:33
专家分:0
注 册:2007-9-23
收藏
得分:0 
但是题目没有说int k=0;

2007-11-04 13:28
毛山道士
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2007-11-4
收藏
得分:0 
2楼上的兄弟说的对啊
2007-11-04 15:18
快速回复:递归法数组倒置
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.040135 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved