//FunctionTemplate.h
#ifndef FUNCTIONTEMPLATE
#define FUNCTIONTEMPLATE
template<typename Type>int Sort(Type b[],int m)
{ int i,temp,n=0;
for(i=0;i<n;i++)
{ if(b[i]>b[i+1])
{ temp=b[i];
b[i]=b[i+1];
b[i+1]=temp;}
}
for( i=0;i<n;i++)
cout<<b[i]<<" ";
return b[i];}
#endif
//10.1.cpp
#include "stdafx.h"
#include"FunctionTemplate.h"
#include <iostream>
#include<string>
using namespace std;
int main()
{ int n,i;int a[100000];
cout<<"请输入数组的元素个数:"<<endl;
cin>>n;
cout<<"请输入数组的元素:"<<endl;
for(i=0;i<n;i++){ cin>>a[i];}
cout<<"对此数组进行升序排列:"<<endl;
cout<<Sort(a,n)<<endl;
return 0;
}
想要输出数组,应该return什么
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
4条回答 默认 最新
- 鞠杉 2021-02-21 10:06关注
return语句是函数的返回值,且只能执行一次程序就终止了,想要返回数组,首先需要确保你的函数返回值类型与数组存储的数据类型的指针类型一致,你此处使用的是模板函数,数组存储的数据类型是Type,因此函数的返回值应该是Type*,具体见代码修改。
//代码修改 //将代码整合为一个cpp文件,也可以分文件写。 #include <iostream> #include<string> using namespace std; //修改返回值为Type*类型为返回数组的地址 template<typename Type> Type* Sort(Type b[],int m) { //重新修改排序算法,采用选择排序 int i,index; for(i=0;i<m-1;i++){ index = i; int j; for(j=i+1;j<m;j++){ if(b[i]>b[j]){ index = j; } } if(index!=i){ int temp=b[i]; b[i] = b[index]; b[index] = temp; } } //返回数组名即可,即数组的地址 return b; } int main() { int n,i;int a[100000]; cout<<"请输入数组的元素个数:"<<endl; cin>>n; cout<<"请输入数组的元素:"<<endl; for(i=0;i<n;i++){ cin>>a[i];} cout<<"对此数组进行升序排列:"<<endl; //修改Sort模板函数的调用 //返回为指针类型保存到arr中 //循环遍历输出值 int *arr = Sort<int>(a,n); for(int i=0;i<n;i++){ cout<<arr[i]<<" "; } return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 关于#hadoop#的问题
- ¥15 (标签-Python|关键词-socket)
- ¥15 keil里为什么main.c定义的函数在it.c调用不了
- ¥50 切换TabTip键盘的输入法
- ¥15 可否在不同线程中调用封装数据库操作的类
- ¥15 微带串馈天线阵列每个阵元宽度计算
- ¥15 keil的map文件中Image component sizes各项意思
- ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
- ¥15 划分vlan后,链路不通了?
- ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据