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

linxuex

C++學習者

常用鏈接

統(tǒng)計

最新評論

請 教

編一個程序,用同一個函數(shù)名對n個數(shù)據(jù)進行從小到大排序,數(shù)據(jù)類型可以是整型,單精度型,雙精度型。用重載函數(shù)實現(xià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

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

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

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

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

像這種插入排序要注意排序的個數(shù),是
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個數(shù)
若j<4 j取0,1,2,3四個數(shù)
我調(diào)了一下你給的 沒調(diào)出來



能不能幫我再調(diào)一下 謝謝!!!!!!!!!!!!!  回復  更多評論   

# 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]!
我前面寫錯了, 外循環(huán)不要改, 改后如下:
for(j=0;j<5;j++)
{
for(i=0;i<4-j;i++) //內(nèi)循環(huán)改一下
{
if(a[i]>a[i+1])
...}
}


我運行結(jié)果良好,怎么會調(diào)不出來  回復  更多評論   

# 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]);//標準庫里好像有這個函數(shù)
}
}
}

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

# 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]是哪個元素啊~這時不是越界了。
所以我感覺應(yīng)該是這樣寫:
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]);//標準庫里好像有這個函數(shù)
}

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

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

內(nèi)循環(huán)for(j=i; j<n-1-i; j++)的j至少要固定一端, 兩端都與i相關(guān),必錯.
正解如下:
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]);//標準庫函數(shù)
}
}
}  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久免费视频在线| 亚洲天天影视| 牛牛国产精品| 老司机成人网| 在线观看精品一区| 欧美大片在线观看| 亚洲专区免费| 欧美黄色aaaa| 亚洲欧美国产视频| 国产一区再线| 欧美日韩成人| 久久国产精品一区二区| 亚洲欧洲精品一区二区精品久久久| 欧美一区二区三区四区高清| 欧美不卡在线| 亚洲欧美日韩国产一区| 欧美一区二区免费观在线| 91久久亚洲| 国产精品欧美日韩久久| 久久综合九色99| 欧美亚洲综合另类| 麻豆久久久9性大片| 欧美一区午夜视频在线观看| 夜夜嗨av一区二区三区中文字幕| 久久在线观看视频| 欧美中文在线观看| 99xxxx成人网| 亚洲第一精品夜夜躁人人爽| 国产精品久久久久久久久久三级 | 欧美一区视频在线| 美国十次了思思久久精品导航| 国产欧美日韩精品丝袜高跟鞋 | 99精品国产一区二区青青牛奶| 亚洲在线观看免费| 亚洲综合色视频| 女人天堂亚洲aⅴ在线观看| 欧美四级在线观看| 欧美三级网址| 亚洲国产日韩欧美综合久久| 在线观看不卡| 久久av一区二区| 99re66热这里只有精品4| 亚洲国产精品尤物yw在线观看| 久久久久久久一区二区三区| 午夜精品av| 午夜精品久久久久久久99热浪潮| 麻豆乱码国产一区二区三区| 正在播放日韩| 中日韩美女免费视频网址在线观看 | 亚洲卡通欧美制服中文| 亚洲美女免费精品视频在线观看| 欧美在线一二三四区| 9i看片成人免费高清| 欧美成人亚洲成人日韩成人| 伊人一区二区三区久久精品| 久久成人人人人精品欧| 亚洲一区二区三区高清不卡| 欧美午夜国产| 国际精品欧美精品| 亚洲欧美精品一区| 一区二区欧美激情| 欧美一级网站| 国产精品午夜av在线| 亚洲综合视频1区| 久久精品一区二区三区不卡牛牛 | 欧美日韩亚洲在线| 国产欧美一区二区三区沐欲| 制服诱惑一区二区| 久久精品国语| 亚洲第一网站| 亚洲欧美不卡| 国产婷婷一区二区| 99视频精品免费观看| 亚洲一区二区欧美| 久久久久久精| 久久aⅴ国产欧美74aaa| 韩国自拍一区| 亚洲在线免费视频| 欧美亚洲一级| 亚洲激情在线激情| 亚洲四色影视在线观看| 亚洲国产裸拍裸体视频在线观看乱了中文 | 蜜臀a∨国产成人精品| 久久免费黄色| 日韩午夜在线| 在线中文字幕一区| 国产精品主播| 国产婷婷色综合av蜜臀av| 久久国产主播| 欧美成人嫩草网站| 亚洲综合日韩在线| 欧美在线免费观看视频| 日韩一级精品| 欧美伊人久久久久久久久影院| 亚洲电影成人| 亚洲综合色噜噜狠狠| 亚洲国产综合在线| 亚洲天堂激情| 亚洲免费成人av| 亚洲欧美国产一区二区三区| 亚洲国产精品123| 久久久久看片| 亚洲夜晚福利在线观看| 狠狠入ady亚洲精品经典电影| 亚洲动漫精品| 国产日韩一区二区三区在线| 亚洲激情啪啪| 黄色成人av| 中文亚洲欧美| 99www免费人成精品| 久久久www免费人成黑人精品| 国产午夜精品在线观看| 亚洲第一狼人社区| 国产综合视频在线观看| 这里只有精品电影| 91久久精品网| 久久久www成人免费精品| 欧美国产综合视频| 91久久久久久国产精品| 亚洲欧美文学| 黄色成人精品网站| 亚洲新中文字幕| 99精品国产99久久久久久福利| 久久爱www久久做| 午夜精品国产更新| 欧美日韩国产丝袜另类| 欧美高清自拍一区| 欧美黑人国产人伦爽爽爽| 久久www成人_看片免费不卡| 欧美日韩一区二区在线观看| 亚洲大胆女人| 欧美日韩国产成人在线免费| 麻豆视频一区二区| 一区福利视频| 亚洲欧洲精品一区二区| 亚洲国产精品久久久久久女王| 性色一区二区三区| 亚洲国产经典视频| 老牛国产精品一区的观看方式| 久久九九全国免费精品观看| 国产欧美欧洲在线观看| 欧美一进一出视频| 久久综合伊人77777蜜臀| 狠狠色香婷婷久久亚洲精品| 欧美在线日韩精品| 欧美成人一区二区| 一本到12不卡视频在线dvd| 欧美激情久久久| 亚洲理伦在线| 国语对白精品一区二区| 久久久久欧美精品| 亚洲欧美一区二区三区极速播放 | 在线观看国产精品淫| 玖玖国产精品视频| 亚洲第一精品福利| 一区二区三区日韩| 久久精品亚洲热| 欧美jizz19性欧美| 亚洲激情啪啪| 欧美日本精品在线| 欧美不卡在线| 日韩视频在线一区二区| 欧美欧美全黄| 亚洲欧美激情视频在线观看一区二区三区 | 亚洲欧美国产不卡| 欧美高清视频免费观看| 91久久香蕉国产日韩欧美9色 | 亚洲欧美日本国产专区一区| 一区二区三区欧美| 国产精品日本一区二区| 欧美在线视频播放| 亚洲国内精品在线| 亚洲一区二区三区涩| 国产一区91| 欧美国产精品va在线观看| 亚洲精品乱码| 久久久久99精品国产片| 亚洲高清色综合| 亚洲你懂的在线视频| 今天的高清视频免费播放成人| 欧美国产专区| 久久福利电影| 9色国产精品| 免费国产一区二区| 亚洲欧美综合精品久久成人| 亚洲国产mv| 国产精品自拍小视频| 欧美国产成人在线| 久久国产综合精品| 亚洲一区综合| 亚洲毛片视频| 欧美国产一区二区| 久久在线免费观看| 欧美永久精品| 亚洲午夜极品| 亚洲美女视频在线观看| 精品69视频一区二区三区| 国产精品久久久久影院亚瑟| 欧美国产日韩精品免费观看| 久久久久高清|