• <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>

            linxuex

            C++學(xué)習(xí)者

            常用鏈接

            統(tǒng)計(jì)

            最新評(píng)論

            請(qǐng) 教

            編一個(gè)程序,用同一個(gè)函數(shù)名對(duì)n個(gè)數(shù)據(jù)進(jìn)行從小到大排序,數(shù)據(jù)類型可以是整型,單精度型,雙精度型。用重載函數(shù)實(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)  請(qǐng)問(wèn)是什么原因?如何解決?
                                                                                                                                C++初學(xué)習(xí)者

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

            評(píng)論

            # re: 請(qǐng) 教 2007-04-21 09:48 pengkuny

            函數(shù)定義時(shí)形參沒(méi)有變量名  回復(fù)  更多評(píng)論   

            # re: 請(qǐng) 教 2007-04-21 09:49 pengkuny

            for(j=0;j<5;j++)到處copy,第三個(gè)j沒(méi)有改成i
              回復(fù)  更多評(píng)論   

            # re: 請(qǐng) 教 2007-04-21 09:51 pengkuny

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

            # re: 請(qǐng) 教 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");
            }  回復(fù)  更多評(píng)論   

            # re: 請(qǐng) 教 2007-04-21 09:57 wzqxp2002

            干嗎不用模版哦?  回復(fù)  更多評(píng)論   

            # re: 請(qǐng) 教 2007-04-21 14:38 linxuex

            我覺(jué)得沒(méi)越界j<5表示j取0,1,2,3,4可表示5個(gè)數(shù)
            若j<4 j取0,1,2,3四個(gè)數(shù)
            我調(diào)了一下你給的 沒(méi)調(diào)出來(lái)



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

            # re: 請(qǐng) 教 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;
            }

              回復(fù)  更多評(píng)論   

            # re: 請(qǐng) 教 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])
            ...}
            }
            怎么沒(méi)越界,j = 0, i = 4, a[i+1]越界a[5]!
            我前面寫(xiě)錯(cuò)了, 外循環(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])
            ...}
            }


            我運(yùn)行結(jié)果良好,怎么會(huì)調(diào)不出來(lái)  回復(fù)  更多評(píng)論   

            # re: 請(qǐng) 教 2007-04-21 18:57 踏雪赤兔

            怎么不寫(xiě)成template  回復(fù)  更多評(píng)論   

            # re: 請(qǐng) 教 2007-04-22 09:11 jarod-pku

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

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

            寫(xiě)成template要方便很多。
              回復(fù)  更多評(píng)論   

            # re: 請(qǐng) 教 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]);//標(biāo)準(zhǔn)庫(kù)里好像有這個(gè)函數(shù)
            }
            }
            }

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

            # re: 請(qǐng) 教 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])
            這里出問(wèn)題了
            當(dāng)j=0,i=4時(shí),a[i+1]是哪個(gè)元素啊~這時(shí)不是越界了。
            所以我感覺(jué)應(yīng)該是這樣寫(xiě):
            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]);//標(biāo)準(zhǔn)庫(kù)里好像有這個(gè)函數(shù)
            }

            用模板寫(xiě)就省很多功夫了  回復(fù)  更多評(píng)論   

            # re: 請(qǐng) 教 2007-04-28 20:59 pengkuny

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


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            一本久久a久久精品综合香蕉| 久久国产亚洲精品| 精品国产乱码久久久久久人妻| 国产精品久久久久一区二区三区 | 国产69精品久久久久99| 亚洲成人精品久久| 久久久久久久国产免费看| 四虎影视久久久免费| 2021国内精品久久久久久影院| 欧美精品久久久久久久自慰| 国产亚洲色婷婷久久99精品| 久久精品国产一区二区三区不卡| 无码精品久久一区二区三区| 久久精品国产99国产精品导航 | 国内精品人妻无码久久久影院| 国产99久久精品一区二区| 九九久久精品国产| 午夜精品久久久久久久| 国产福利电影一区二区三区,免费久久久久久久精 | 久久天天躁狠狠躁夜夜96流白浆| 亚洲综合精品香蕉久久网97| 久久精品国产一区二区电影| 狠狠色婷婷久久一区二区三区| 久久综合九色欧美综合狠狠| 久久精品国产99久久久| 久久久免费观成人影院| 97r久久精品国产99国产精| 色偷偷88欧美精品久久久| 2020久久精品国产免费| 亚洲综合伊人久久综合| 久久亚洲精品无码播放| 久久九九有精品国产23百花影院| 久久久久亚洲AV无码观看| 国产精品永久久久久久久久久| 久久久久亚洲AV片无码下载蜜桃| 国产免费久久精品99re丫y| 久久精品国产亚洲一区二区三区| 久久久久久久99精品免费观看| 久久久无码人妻精品无码| 亚洲精品蜜桃久久久久久| 国内精品人妻无码久久久影院导航 |