• <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 煙皚 閱讀(353) 評論(0)  編輯 收藏 引用 所屬分類: C++ primer plus學習筆記
            久久精品麻豆日日躁夜夜躁| 三级三级久久三级久久| 亚洲va久久久噜噜噜久久| 国产A级毛片久久久精品毛片| 伊人久久免费视频| 精品久久久久久国产牛牛app| 69久久夜色精品国产69| 欧美色综合久久久久久| 7777精品伊人久久久大香线蕉 | 亚洲中文字幕无码久久2017| 久久国语露脸国产精品电影| 国产精品久久久久jk制服| 青青草原综合久久大伊人导航| 欧美亚洲色综久久精品国产| 久久精品国产精品亚洲下载| 国产精品久久久久影院嫩草 | 久久婷婷久久一区二区三区| 久久97久久97精品免视看| 亚洲国产另类久久久精品黑人| 久久综合亚洲色HEZYO国产| 久久久综合九色合综国产| 浪潮AV色综合久久天堂| 蜜臀久久99精品久久久久久| 麻豆精品久久精品色综合| 久久精品国产亚洲av影院| 亚洲国产精品无码久久九九| 国产精品熟女福利久久AV| 2021久久国自产拍精品| 久久精品天天中文字幕人妻| 伊人久久大香线蕉综合影院首页| 亚洲国产欧美国产综合久久| 日本WV一本一道久久香蕉| 国内精品久久久久影院老司| 综合久久精品色| 伊人久久无码精品中文字幕| 午夜精品久久久久| 国产成人无码精品久久久性色| 久久久久国产精品嫩草影院| 久久久这里有精品| 久久青青草原精品国产| 久久国产精品-国产精品|