• <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學習筆記
            精品无码人妻久久久久久| 久久精品人人做人人爽电影| 久久久久亚洲av无码专区| 久久天天躁狠狠躁夜夜avapp | 伊人久久大香线蕉亚洲| 久久久久亚洲精品无码蜜桃| 色综合色天天久久婷婷基地| 久久笫一福利免费导航| 麻豆亚洲AV永久无码精品久久| 久久99中文字幕久久| 无码国内精品久久综合88| 九九99精品久久久久久| 久久香综合精品久久伊人| 国产精品久久久亚洲| 色婷婷久久久SWAG精品| 久久99久久99小草精品免视看| 狠狠色噜噜色狠狠狠综合久久| 97久久精品人人做人人爽| 无码日韩人妻精品久久蜜桃| 久久精品国产精品亜洲毛片| 99久久精品毛片免费播放| 久久精品成人欧美大片| 要久久爱在线免费观看| 久久艹国产| 久久国产热这里只有精品| 久久久精品人妻一区二区三区四| 久久无码人妻一区二区三区| 亚洲国产精品成人久久蜜臀| 丰满少妇人妻久久久久久4| 囯产极品美女高潮无套久久久| 欧美日韩成人精品久久久免费看| 人人狠狠综合久久亚洲婷婷| 婷婷综合久久中文字幕蜜桃三电影| 亚洲精品WWW久久久久久| 四虎国产精品成人免费久久| 国产午夜电影久久| 国产日韩久久免费影院| 久久久久国产亚洲AV麻豆| 国产日韩久久免费影院| 久久无码精品一区二区三区| 久久久久无码专区亚洲av|