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

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>
            国产最新精品精品你懂的| 久久国产婷婷国产香蕉| 欧美日韩中文| 欧美日韩999| 欧美日韩精品福利| 国产精品久久波多野结衣| 国产精品久久久久国产精品日日| 欧美日韩一区二区视频在线| 欧美视频在线观看视频极品 | 亚洲高清久久| 亚洲成人在线免费| 亚洲一区二区高清| 亚洲免费中文| 久久香蕉精品| 欧美日韩在线看| 国产日韩欧美不卡| 在线观看欧美一区| 中国女人久久久| 久久国产视频网站| 亚洲精品小视频在线观看| 亚洲综合欧美日韩| 欧美va亚洲va香蕉在线| 欧美性色视频在线| 亚洲国产精品黑人久久久| 亚洲综合电影| 欧美 日韩 国产 一区| 一本一本a久久| 麻豆久久久9性大片| 国产精品av免费在线观看 | 狠狠色狠狠色综合| 正在播放欧美视频| 老司机免费视频一区二区三区| 亚洲精品小视频| 蜜臀91精品一区二区三区| 国产精品日韩一区| 亚洲美女福利视频网站| 久久久精品一区| 亚洲视频免费在线| 欧美激情视频一区二区三区不卡| 国产一区二区成人| 亚洲综合视频1区| 亚洲全黄一级网站| 蜜桃av久久久亚洲精品| 国产综合av| 亚洲欧美日韩第一区| 亚洲欧洲综合另类在线| 久久久久国产精品一区三寸| 亚洲黄色成人| 久久精品水蜜桃av综合天堂| 欧美视频一区二区三区四区| 夜夜精品视频| 亚洲高清资源| 久久只精品国产| 韩国av一区二区| 欧美一区二区播放| 亚洲一区视频在线观看视频| 欧美视频在线观看视频极品| 一区二区av| 一区二区三区 在线观看视| 欧美精品亚洲一区二区在线播放| 亚洲国产精品va| 欧美激情va永久在线播放| 久久综合激情| 亚洲美洲欧洲综合国产一区| 亚洲国产高清在线| 欧美激情一区在线| 一片黄亚洲嫩模| 一区二区免费在线播放| 国产精品久久久久aaaa樱花| 午夜精品www| 午夜免费电影一区在线观看| 国产日本欧美在线观看| 久久精品免费播放| 玖玖国产精品视频| 99视频精品| 亚洲一区二区3| 国产综合自拍| 亚洲欧洲一区二区在线播放| 欧美性猛交99久久久久99按摩| 欧美一级视频| 久久蜜桃香蕉精品一区二区三区| 亚洲国产精品成人| 亚洲另类在线视频| 国产精品久久久久久久久搜平片| 午夜综合激情| 久久蜜臀精品av| 正在播放亚洲| 欧美一级午夜免费电影| 亚洲国产精品一区二区第一页| 亚洲日本中文字幕| 国产精品久久久久一区二区三区共 | 欧美高清视频在线| 欧美另类变人与禽xxxxx| 亚洲永久网站| 久久久久国产精品一区二区| 一个人看的www久久| 午夜精品福利一区二区蜜股av| 狠狠操狠狠色综合网| 亚洲国产精品尤物yw在线观看| 国产精品久久久久久久久搜平片| 狼人社综合社区| 国产精品久线观看视频| 欧美激情第一页xxx| 国产精品日韩久久久久| 亚洲美女免费视频| 亚洲午夜久久久久久久久电影院| 伊人久久av导航| 亚洲小说区图片区| 91久久中文字幕| 香蕉久久a毛片| 亚洲无限乱码一二三四麻| 久久精品一本| 亚洲女性裸体视频| 免费的成人av| 久久久久中文| 国产精品视频yy9299一区| 亚洲电影免费| 激情综合色丁香一区二区| 亚洲图片欧美午夜| 在线亚洲精品| 欧美精品一区二区在线播放| 久久综合久色欧美综合狠狠| 国产精品毛片大码女人| 亚洲精品精选| 亚洲美女免费精品视频在线观看| 久久国产日韩欧美| 久久超碰97人人做人人爱| 欧美日韩免费在线视频| 亚洲第一主播视频| 亚洲国产精品悠悠久久琪琪| 久久久91精品国产一区二区三区 | 久久久国产午夜精品| 性做久久久久久久免费看| 欧美日韩国产系列| 亚洲国产天堂久久国产91| 在线日韩一区二区| 久久久高清一区二区三区| 久久精品亚洲一区二区| 国产精品jvid在线观看蜜臀| 亚洲精品视频二区| 亚洲小视频在线| 欧美性淫爽ww久久久久无| 99riav国产精品| 亚洲一区二区三区久久| 欧美日韩另类视频| 在线一区欧美| 欧美在线高清| 黄色免费成人| 老司机久久99久久精品播放免费| 欧美插天视频在线播放| 亚洲人成网站999久久久综合| 欧美不卡一卡二卡免费版| 亚洲国产精品ⅴa在线观看 | 先锋资源久久| 老司机精品久久| 亚洲精品国产精品国自产观看浪潮| 麻豆精品国产91久久久久久| 亚洲福利视频网| 一区二区三区蜜桃网| 国产精品国产一区二区 | 久久米奇亚洲| 日韩午夜在线视频| 欧美一区二区视频97| 狠狠久久亚洲欧美专区| 免费观看成人网| 一区二区三区久久| 极品少妇一区二区三区精品视频| 久久精品系列| 亚洲久久一区二区| 欧美在线看片a免费观看| 亚洲国产高清视频| 国产精品九九久久久久久久| 午夜精品一区二区三区在线播放 | 久久免费99精品久久久久久| 亚洲激情小视频| 久久国产精品一区二区| 亚洲精品视频免费观看| 国产精品免费看久久久香蕉| 久久久久国产精品厨房| 日韩午夜电影| 免费一区二区三区| 亚洲欧洲av一区二区三区久久| 尤物yw午夜国产精品视频| 欧美特黄一区| 免费成人性网站| 欧美亚洲三区| 亚洲精品一区二区三| 老司机精品导航| 新狼窝色av性久久久久久| 亚洲伦理精品| 一区精品在线播放| 国产精品推荐精品| 欧美日韩一区二区免费视频| 久久综合激情| 欧美主播一区二区三区美女 久久精品人| 亚洲国产成人在线| 久久尤物视频| 久久国产精品色婷婷| 亚洲欧美色婷婷| 一区二区三区久久|