| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1897 人关注过本帖
标题:请教高手一个问题(是道作业来的)
取消只看楼主 加入收藏
garyxuan
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2004-8-23
收藏
 问题点数:0 回复次数:5 
请教高手一个问题(是道作业来的)

编一个冒泡排序的函数模板实现降序.可以用小于比较,冒泡采用从上往下;也可用大于比较,冒泡采用从下往上.

搜索更多相关主题的帖子: 作业 模板 冒泡 
2004-11-05 19:38
garyxuan
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2004-8-23
收藏
得分:0 
大哥,我当然有冒泡的原码了,我现刚学到模板了,但不是很懂,要通过函数模板来实现这个冒泡,应该怎样做啊
2004-11-06 10:37
garyxuan
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2004-8-23
收藏
得分:0 

我已编写了一个,可以运行,但离题目的要求还差一点点,请版主帮我看看:

template<typename T> void enter(T a[],int); template<typename T> void bubble(T a[],int); template<typename T> void print(T a[],int);

int _tmain() { int a[100],size; cout<<"请确定数组的大小:"; cin>>size; enter(a,size); bubble(a,size); print(a,size); return 0; }

template<typename T> void enter(T a[],int n) { int i; cout<<"请输入"<<n<<"个元素:"; for(i=0;i<n;i++) cin>>a[i]; cout<<"未排序的数组元素为:"<<endl; for(i=0;i<n;i++) cout<<a[i]<<" "; cout<<endl; } template<typename T> void bubble(T a[],int n) { int i,j,t,temp; for(i=1;i<=n-1;i++) { t=n-i; for(j=0;j<=t-1;j++) if(a[j]<a[j+1]) {temp=a[j];a[j]=a[j+1];a[j+1]=temp;} } } template<typename T> void print(T a[],int n) { int i; cout<<"排序后的数组元素为:"<<endl; for(i=0;i<n;i++) cout<<a[i]<<" "; cout<<endl; }

2004-11-06 16:13
garyxuan
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2004-8-23
收藏
得分:0 

我的这个排序是适用第一种情况:(用小于比较,冒泡采用从上往下),主要是如何实现(也可用大于比较,冒泡采用从下往上),我把其中的bubble()函数改了一下:

template<typename T> void bubble(T a[],int n) { int i,j,t,temp; for(i=n-1;i>=1;i--) { t=n-i; for(j=t;j>=1;j--) if(a[j]>a[j-1]) {temp=a[j];a[j]=a[j-1];a[j-1]=temp;} } } 请问这个是不是(用大于比较,冒泡采用从下往上),如果是,请问如何与从上往下的统一成一个函数模板

如果不是,请版主帮我修改,麻烦了,我下周二要交上去

2004-11-06 16:21
garyxuan
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2004-8-23
收藏
得分:0 

呵呵,我没看清楚题目,以为是要适用于两种情况,那这道题我已经完成了.多谢版主了.

顺便提一下,我在运行这个程序前,对于输出数组元素并不是用循环,

for(i=0;i<n;i++) cout<<a[i]<<" "; cout<<endl;

而是直接用:cout<<a<<endl;但这样不能正确输出,输出一些不知道的东西,请问版主这是怎么一回事.

2004-11-06 20:45
garyxuan
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2004-8-23
收藏
得分:0 

我想应该是和版主说的一样,那多谢了,不过我要再好好研究一下,我才刚学到吗

2004-11-07 14:18
快速回复:请教高手一个问题(是道作业来的)
数据加载中...
 
   



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

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