青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

linxuex

C++學習者

常用鏈接

統計

最新評論

請 教

編一個程序,用同一個函數名對n個數據進行從小到大排序,數據類型可以是整型,單精度型,雙精度型。用重載函數實現
#include<iostream>
#include<string>
using namespace std;
int main()
{ long a[5]={10100, -123567, 1198783, -165654, 3456};
  int b[5]={1,9,0,23,-45};
  float c[5]={2.4,7.6,5.5,6.6,-2.3};
  void sort(long []);
  void sort(int []);
  void sort(float []);
  sort(a);
  sort(b);
  sort(c);
  return 0;
}

void sort(long [])
{int i,j;
 long t;
 for(j=0;j<5;j++)
   for(i=0;i<5-j;;j++)
    if(a[i]>a[i+1])
    {t=a[i];a[i]=a[i+1];a[i+1]=t;}
 cout<<"the sorted numbers:"<<endl;
 for(i=0;i<5;j++)
  cout<<a[i]<<" ";
 cout<<endl<<endl;
}

void sort(int [])
{int i,j,t;
 for(j=0;j<5;j++)
   for(i=0;i<5-j;;j++)
    if(a[i]>a[i+1])
    {t=a[i];a[i]=a[i+1];a[i+1]=t;}
 cout<<"the sorted numbers:"<<endl;
 for(i=0;i<5;j++)
  cout<<a[i]<<" ";
 cout<<endl<<endl;
}

void sort(float [])
{int i,j;
 float t;
 for(j=0;j<5;j++)
   for(i=0;i<5-j;;j++)
    if(a[i]>a[i+1])
    {t=a[i];a[i]=a[i+1];a[i+1]=t;}
 cout<<"the sorted numbers:"<<endl;
 for(i=0;i<5;j++)
  cout<<a[i]<<" ";
 cout<<endl<<endl;
}

 
 //d:\c++6.0\vs63in1 (g)\vc60chs\vc98\include\ios(9) : fatal error C1083: Cannot open include file: 'streambuf.h': No such file or directory
Cpp1.obj - 1 error(s), 0 warning(s)  請問是什么原因?如何解決?
                                                                                                                    C++初學習者

posted on 2007-04-21 09:14 linxuex 閱讀(887) 評論(13)  編輯 收藏 引用

評論

# re: 請 教 2007-04-21 09:48 pengkuny

函數定義時形參沒有變量名  回復  更多評論   

# re: 請 教 2007-04-21 09:49 pengkuny

for(j=0;j<5;j++)到處copy,第三個j沒有改成i
  回復  更多評論   

# re: 請 教 2007-04-21 09:51 pengkuny

像這種插入排序要注意排序的個數,是
for(j=0;j<4;j++) 不是j <5
否則后面a[i]>a[i+1]就越界了  回復  更多評論   

# re: 請 教 2007-04-21 09:52 pengkuny

算了,編譯了一下:
#include "stdafx.h"
#include<iostream>
//#include<string>

using namespace std;

int main()
{
long a[5]={10100, -123567, 1198783, -165654, 3456};
int b[5]={1,9,0,23,-45};
double c[5]={2.4,7.6,5.5,6.6,-2.3};
void sort(long []);
void sort(int []);
void sort(double []);
sort(a);
sort(b);
sort(c);
return 0;
system("pause");
}

void sort(long a[])
{
int i,j;
long t;
for(j=0;j<4;j++)
{
for(i=0;i<4-j;i++)
{
if(a[i]>a[i+1])
{
t=a[i];a[i]=a[i+1];a[i+1]=t;
}
}
}
cout<<"the sorted numbers:"<<endl;
for(i=0;i<5;i++)
cout<<a[i]<<" ";
cout<<endl<<endl;
system("pause");
}

void sort(int a[])
{
int i,j,t;
for(j=0;j<4;j++)
{
for(i=0;i<4-j;i++)
{
if(a[i]>a[i+1])
{
t=a[i];a[i]=a[i+1];a[i+1]=t;
}
}
}
cout<<"the sorted numbers:"<<endl;
for(i=0;i<5;i++)
cout<<a[i]<<" ";
cout<<endl<<endl;
system("pause");
}

void sort(double a[])
{
int i,j;
double t;
for(j=0;j<4;j++)
{
for(i=0;i<4-j;i++)
{
if(a[i]>a[i+1])
{
t=a[i];a[i]=a[i+1];a[i+1]=t;
}
}
}
cout<<"the sorted numbers:"<<endl;
for(i=0;i<5;i++)
cout<<a[i]<<" ";
cout<<endl<<endl;
system("pause");
}  回復  更多評論   

# re: 請 教 2007-04-21 09:57 wzqxp2002

干嗎不用模版哦?  回復  更多評論   

# re: 請 教 2007-04-21 14:38 linxuex

我覺得沒越界j<5表示j取0,1,2,3,4可表示5個數
若j<4 j取0,1,2,3四個數
我調了一下你給的 沒調出來



能不能幫我再調一下 謝謝!!!!!!!!!!!!!  回復  更多評論   

# re: 請 教 2007-04-21 14:49 tivili_chen

#include<iostream>
#include<string>
using namespace std;
void sort(long []);
void sort(int []);
void sort(float []);
int main()
{ long a[5]={10100, -123567, 1198783, -165654, 3456};
int b[5]={1,9,0,23,-45};
float c[5]={2.4f,7.6f,5.5f,6.6f,-2.3f};

sort(a);
sort(b);
sort(c);
return 0;
}

void sort(long a[])
{int i,j;
long t;
for(j=0;j<5;j++)
for(i=0;i<5-j;i++)
if(a[i]>a[i+1])
{t=a[i];a[i]=a[i+1];a[i+1]=t;}
cout<<"the sorted numbers:"<<endl;
for(i=0;i<5;i++)
cout<<a[i]<<" ";
cout<<endl<<endl;
}

void sort(int a[])
{int i,j,t;
for(j=0;j<5;j++)
for(i=0;i<5-j;i++)
if(a[i]>a[i+1])
{t=a[i];a[i]=a[i+1];a[i+1]=t;}
cout<<"the sorted numbers:"<<endl;
for(i=0;i<5;i++)
cout<<a[i]<<" ";
cout<<endl<<endl;
}

void sort(float a[])
{int i,j;
float t;
for(j=0;j<5;j++)
for(i=0;i<5-j;i++)
if(a[i]>a[i+1])
{t=a[i];a[i]=a[i+1];a[i+1]=t;}
cout<<"the sorted numbers:"<<endl;
for(i=0;i<5;i++)
cout<<a[i]<<" ";
cout<<endl<<endl;
}

  回復  更多評論   

# re: 請 教 2007-04-21 15:36 pengkuny

for(j=0;j<5;j++)
{
for(i=0;i<5-j;i++)
{
if(a[i]>a[i+1])
...}
}
怎么沒越界,j = 0, i = 4, a[i+1]越界a[5]!
我前面寫錯了, 外循環不要改, 改后如下:
for(j=0;j<5;j++)
{
for(i=0;i<4-j;i++) //內循環改一下
{
if(a[i]>a[i+1])
...}
}


我運行結果良好,怎么會調不出來  回復  更多評論   

# re: 請 教 2007-04-21 18:57 踏雪赤兔

怎么不寫成template  回復  更多評論   

# re: 請 教 2007-04-22 09:11 jarod-pku

代碼的毛病還是比較多的。

另外,VC6的庫比較老,對"iostream"的支持不好。一般都是用.h的老庫。

寫成template要方便很多。
  回復  更多評論   

# re: 請 教 2007-04-22 10:13 chenger

用模板不是更好?
template <typename T>
void sort(T v[],int size)
{
for(int i = 0;i < size;++i)
{
for(int j = i;j < size - 1;++j)
{
if(a[j]>a[j+1])
swap(a[j],a[j+1]);//標準庫里好像有這個函數
}
}
}

不知道對不對……這個sort,如果代碼沒錯的話,可以適用于所有能夠用<比較大小的類型,此外要支持賦值,總之要讓swap函數能工作。當然,更好的辦法是提供兩個迭代器begin,end指明排序范圍。建議樓主去看看STL里算法的實現。  回復  更多評論   

# re: 請 教 2007-04-27 11:03 sandy

for(j=0;j<5;j++)
for(i=j;i<5-j;i++)
if(a[i]>a[i+1])
這里出問題了
當j=0,i=4時,a[i+1]是哪個元素啊~這時不是越界了。
所以我感覺應該是這樣寫:
template <typename T>
void sort(T v[],int size)
{
for(int i = 0;i < size;++i)
for(int j = i;j < size - 1-i;++j)
if(a[j]>a[j+1])
swap(a[j],a[j+1]);//標準庫里好像有這個函數
}

用模板寫就省很多功夫了  回復  更多評論   

# re: 請 教 2007-04-28 20:59 pengkuny

內循環for(j=i; j<n-1-i; j++)的j至少要固定一端, 兩端都與i相關,必錯.
正解如下:
for(i=0; i<n; i++)//排序
{
for(j=0; j<n-1-i; j++)
{
if(x[j] > x[j+1])
{
swap(x[j],x[j+1]);//標準庫函數
}
}
}  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲第一在线| 欧美黑人国产人伦爽爽爽| 亚洲精品美女在线观看| 亚洲丶国产丶欧美一区二区三区| 日韩一级网站| 欧美一区免费| 亚洲高清免费在线| 久久九九电影| 国产精品久久久久久久久久ktv| 狠狠久久亚洲欧美专区| 国产精品99久久99久久久二8| 久久久久久久久岛国免费| 亚洲激情第一页| 久久九九全国免费精品观看| 影院欧美亚洲| 性欧美18~19sex高清播放| 欧美激情第1页| 久久福利电影| 久久精品成人| 亚洲午夜精品视频| 亚洲视频一区| 亚洲女人小视频在线观看| 欧美精品导航| 亚洲破处大片| 免费观看在线综合| 一区二区日韩| 欧美激情亚洲激情| 99精品国产在热久久下载| 亚洲视频一区在线观看| 欧美日韩国产一区二区| 樱花yy私人影院亚洲| 亚洲三级视频在线观看| 免费观看国产成人| 国产日韩欧美亚洲| 亚洲午夜激情免费视频| 亚洲欧美999| 亚洲精品裸体| 欧美在线免费| 狠狠色丁香婷婷综合| 亚洲高清免费在线| 国产精品久久午夜| 9久草视频在线视频精品| 欧美高清视频| 欧美日韩福利视频| 亚洲综合视频网| 亚洲欧美网站| 黄色小说综合网站| 亚洲福利久久| 在线播放日韩| 性做久久久久久| 在线免费不卡视频| 在线亚洲成人| 黄色日韩网站视频| 一区二区三区产品免费精品久久75| 136国产福利精品导航网址应用| 午夜亚洲一区| 欧美一区二区三区视频| 欧美日韩亚洲网| 性久久久久久| 国产精品白丝黑袜喷水久久久| 久久久久久网| 欧美喷水视频| 久久av最新网址| 乱人伦精品视频在线观看| 99精品国产在热久久婷婷| 久久夜色精品国产噜噜av| 亚洲精品视频一区| 久久精品噜噜噜成人av农村| 久久人人97超碰精品888| 国产欧美在线看| 亚洲国产视频一区| 欧美日韩一区国产| 亚洲国产精品高清久久久| 亚洲国产高清在线观看视频| 亚洲免费在线视频| 亚洲色图在线视频| 欧美区二区三区| 日韩网站在线| 1769国内精品视频在线播放| 免费看黄裸体一级大秀欧美| 欧美好吊妞视频| 日韩视频在线观看免费| 欧美激情女人20p| 亚洲精一区二区三区| 午夜精品一区二区三区在线播放 | 女人色偷偷aa久久天堂| 久久久中精品2020中文| 亚洲二区在线视频| 久久亚洲一区二区| 裸体歌舞表演一区二区| 国产精品国内视频| 一区二区久久久久| 亚洲一区精彩视频| 国产精品激情| 久久av二区| 亚洲国产一区二区在线| 亚洲天堂成人| 国产丝袜一区二区| 欧美一区二粉嫩精品国产一线天| 亚洲一区二区三区乱码aⅴ| 欧美天天影院| 9国产精品视频| 日韩一级在线观看| 欧美日韩精品伦理作品在线免费观看| 亚洲视频免费看| 麻豆精品91| 亚洲在线不卡| 亚洲高清免费在线| 欧美日韩国产精品一区| 午夜精彩视频在线观看不卡 | 亚洲一级影院| 国产一区二区三区精品欧美日韩一区二区三区 | 欧美一级片在线播放| 欧美成人一区二区| 在线亚洲观看| 欧美天天综合网| 久久视频在线视频| 亚洲精品一区二区在线| 久久看片网站| 性欧美18~19sex高清播放| 91久久亚洲| 狠狠色丁香久久婷婷综合_中| 国产精品久久久| 欧美国产日本| 美女精品在线| 久久精品网址| 亚洲欧美国产毛片在线| 亚洲美女视频网| 亚洲国产欧美不卡在线观看| 久久婷婷丁香| 亚洲欧洲在线一区| 国产精品夜色7777狼人| 欧美亚洲自偷自偷| 最新日韩在线视频| 久久国产欧美精品| 亚洲精品一二三区| 国产亚洲精久久久久久| 国产精品成人国产乱一区| 欧美成人在线网站| 亚洲精品影视| 亚洲国产精品一区二区第四页av | 亚洲视频综合| 99精品99久久久久久宅男| 欧美激情视频在线免费观看 欧美视频免费一| 先锋影音一区二区三区| 亚洲视频香蕉人妖| 亚洲国产精品第一区二区| 免费在线成人av| 久久这里有精品视频| 久久久久久久久久久久久9999| 久久久之久亚州精品露出| 久久精品视频导航| 先锋影院在线亚洲| 亚洲一区二区免费看| 亚洲性感美女99在线| 亚洲一区三区在线观看| 亚洲欧美电影院| 亚洲国产成人精品视频| 激情成人在线视频| 欧美激情在线免费观看| 欧美日韩成人一区二区| 欧美视频日韩视频| 欧美连裤袜在线视频| 欧美色播在线播放| 欧美天天在线| 国产亚洲精品久久久久动| 国产真实乱偷精品视频免| 欧美日韩成人在线观看| 国产精品久久久久9999| 国产日韩欧美高清| 国产一区二区三区精品欧美日韩一区二区三区 | 欧美一级夜夜爽| 欧美在线国产| 欧美freesex8一10精品| 欧美日韩精品福利| 欧美揉bbbbb揉bbbbb| 国产精品亚洲а∨天堂免在线| 亚洲国产高清一区| 亚洲精品国精品久久99热一| 亚洲女同同性videoxma| 久久亚洲国产成人| 欧美大片免费观看| 亚洲日本成人在线观看| 亚洲欧美日韩国产中文在线| 欧美sm视频| 国产精自产拍久久久久久| 欧美日韩在线播放三区| 国产欧美亚洲视频| 1769国内精品视频在线播放| 午夜精品一区二区三区在线播放| 亚洲欧美日韩精品| 久久久久久久综合狠狠综合| 亚洲国产另类精品专区| 性欧美18~19sex高清播放| 免费视频一区二区三区在线观看| 国产精品毛片va一区二区三区 | 久久久久久午夜| 亚洲美女区一区| 快射av在线播放一区| 免费成人av在线|