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

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              117 Posts :: 2 Stories :: 61 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(8)

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜


            第一個程序:      
            #include "stdafx.h"
            #include 
            <iostream>
            using namespace std;
            struct travel_time
            {
                
            int hours;
                
            int mines;
            }
            ;
            const int Mines_per_hr = 60;
            travel_time sum(travel_time t1, travel_time t2);
            void show_time(travel_time t);
            int main(int argc, char* argv[])
            {
                travel_time day1 
            = {545}
                travel_time day2 
            = {455};
                travel_time trip 
            = sum (day1, day2);
                cout
            <<"Two-day total: ";
                show_time(trip);
                
                travel_time day3
            ={4,32};
                cout
            <<"Three-day total: ";
                show_time(sum(trip,day3));
                
            return 0;
            }

            travel_time sum(travel_time t1, travel_time t2)
            {
                travel_time total;
                total.mines
            =(t1.mines+t2.mines)%Mines_per_hr;
                total.hours
            =t1.hours+t2.hours+(t1.mines+t2.mines)/Mines_per_hr;
                
            return total;
            }

            void show_time(travel_time t)
            {
                cout
            <<t.hours<<" hours, "<<t.mines<<" minutes\n";
            }

            第二個程序:
                  這個例子將定義兩個結構,用于表示兩種不同的描述位置的方法,然后開發一個函數,將一種格式轉換為另一種格式,并顯示結果。
            #include "stdafx.h"
            #include 
            <iostream>
            #include 
            <cmath>
            using namespace std;
            //structure declarations
            struct polar
            {
                
            double distance;    //distance from origin
                double angle;        //direction from origin
            }
            ;
            struct rect
            {
                
            double x;        //horizontal distance from origin
                double y;        //vertical distance from origin
            }
            ;

            // prototypes
            polar rect_to_polar(rect xypos);
            void show_polar(polar dapos);
            int main(int argc, char* argv[])
            {
                rect rplace;
                polar pplace;
                cout
            <<"Enter the x and y values: ";
                
            // 將cin>>用作測試條件消除了這種限制,因為它接受任何有效地數字輸入。
                
            // 在需要使用循環來輸入數字時候,別忘了考慮使用這種方式。另外請記住,
                
            // 非數字輸入將設置一個錯誤條件,禁止進一步讀取輸入。如果程序在輸入
                
            // 循環后還需要進行輸入,則必須使用cin.clear()重置輸入,然后可能需
                
            // 要通過讀取不合法的輸入來丟棄它們。
                while(cin>>rplace.x>>rplace.y)    //slick use of cin
                {
                    pplace 
            = rect_to_polar(rplace);
                    show_polar(pplace);
                    cout
            <<"Next two numbers(q to quit): ";
                }

                cout
            <<"Done.\n";
                
            return 0;
            }


            //convert rectangular to polar coordinates
            polar rect_to_polar(rect xypos)
            {
                polar answer;
                answer.distance
            =sqrt(xypos.x * xypos.x + xypos.y * xypos.y);
                answer.angle
            =atan2(xypos.y, xypos.x);
                
            return answer;    
            }

            //show polar coordinates, converting angle to degrees
            void show_polar(polar dapos)
            {
                
            const double Rad_to_deg=57.29577951;
                cout
            <<"distance = "<<dapos.distance;
                cout
            <<", angle = "<<dapos.angle * Rad_to_deg;
                cout
            <<" degrees\n";
            }

            第三個程序
                  傳遞結構的地址。假設要傳遞結構的地址而不是整個結構以節省時間和空間,則需要重新編寫前面的函數,使用指向結構的指針。對于重新編寫show_polar()函數,需要修改3個地方:1、調用函數時,將結構的地址(&pplace)而不是結構本身(pplace)傳遞給它。2、將形參聲明為指向polar的指針,即polar*類型。由于函數不應該修改結構,因此使用const修飾。3、由于形參是指針而不是結構,因此應使用間接成員操作符(->),而不是成員操作符(句點)。
            #include "stdafx.h"
            #include 
            <iostream>
            #include 
            <cmath>
            using namespace std;
            //structure declarations
            struct polar
            {
                
            double distance;    //distance from origin
                double angle;        //direction from origin
            }
            ;
            struct rect
            {
                
            double x;        //horizontal distance from origin
                double y;        //vertical distance from origin
            }
            ;

            // prototypes
            void rect_to_polar(const rect* pxy, polar* pda);
            void show_polar(const polar *pda);
            int main(int argc, char* argv[])
            {
                rect rplace;
                polar pplace;
                cout
            <<"Enter the x and y values: ";
                
            while(cin>>rplace.x>>rplace.y)    //slick use of cin
                {
                    rect_to_polar(
            &rplace, &pplace);
                    show_polar(
            &pplace);
                    cout
            <<"Next two numbers(q to quit): ";
                }

                cout
            <<"Done.\n";
                
            return 0;
            }

            void rect_to_polar(const rect* pxy, polar* pda)
            {
                pda
            ->distance=sqrt(pxy->* pxy->+ pxy->* pxy->y);
                pda
            ->angle=atan2(pxy->y, pxy->x);
            }

            void show_polar(const polar *pda)
            {
                
            const double Rad_to_deg=57.29577951;
                cout
            <<"distance = "<<pda->distance;
                cout
            <<", angle = "<<pda->angle * Rad_to_deg;
                cout
            <<" degrees\n";
            }
            posted on 2010-02-12 19:02 煙皚 閱讀(346) 評論(0)  編輯 收藏 引用 所屬分類: C++ primer plus學習筆記
            欧美黑人又粗又大久久久| 国产99久久九九精品无码| 性做久久久久久久久浪潮| 久久精品www人人爽人人| 日本精品一区二区久久久| 精品久久777| 亚洲国产精品无码久久久蜜芽 | 久久久久人妻一区精品性色av| 亚洲av成人无码久久精品 | 久久精品国产黑森林| 麻豆亚洲AV永久无码精品久久| 91精品国产高清久久久久久国产嫩草| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 色婷婷久久久SWAG精品| 热re99久久6国产精品免费| 国产成人精品久久亚洲| 少妇久久久久久久久久| 久久综合一区二区无码| 欧美麻豆久久久久久中文| 久久婷婷激情综合色综合俺也去| 久久AⅤ人妻少妇嫩草影院| 亚洲狠狠综合久久| 久久综合狠狠综合久久| 国内精品久久久久影院亚洲| 久久精品视频一| 久久99精品久久久久久9蜜桃| 久久这里只有精品18| 久久精品一本到99热免费| 国产亚洲精久久久久久无码77777| 国产亚洲美女精品久久久2020| 久久精品人妻一区二区三区| a级成人毛片久久| 国产日韩久久久精品影院首页| 久久精品国产亚洲精品2020| 亚洲色大成网站WWW久久九九| 天天综合久久一二三区| 欧美国产成人久久精品| 亚洲精品成人网久久久久久| 久久超碰97人人做人人爱| 国产精品一久久香蕉国产线看观看 | 青青草原1769久久免费播放|