C++_day03

4.2.2 do ...while循環(huán)語句

作用:滿足循環(huán)條件杭跪,執(zhí)行循環(huán)語句

語法:do{循環(huán)語句}while(循環(huán)條件);

注意:與while的區(qū)別在于do...while會先執(zhí)行一次循環(huán)語句,再判斷循環(huán)條件

練習案例:水仙花數(shù)

水仙花數(shù)是指一個三位數(shù)膳帕,它的每個位上的數(shù)字的3次冪之和等于它本身提完,請利用do...while語句形纺,求出所有3位數(shù)字中的水仙花數(shù)。

#include <iostream>
using namespace std;
#include <cmath>

int main()
{
    int num = 100;
    int a = 0;
    int b = 0;
    int c = 0;
    int sum = 0;
    cout << "水仙花數(shù)有:" << endl;
    do 
    {
        a = num % 10;
        b = num / 10 % 10;
        c = num / 100;
        sum = a*a*a + b*b*b + c*c*c;
        if (sum == num)
        {
            cout << num << endl;
        }
        num++;
    } while (num <= 999);
    system("pause");
    return 0;
}

4.2.3 for循環(huán)語句

作用:滿足循環(huán)條件徒欣,執(zhí)行循環(huán)語句

語法:for(起始表達式;條件表達式;末尾循環(huán)體){循環(huán)語句;}

練習案例:敲桌子

案列描述:從1開始數(shù)到數(shù)字100逐样,如果數(shù)字個位含有7,或者數(shù)字十位含有7打肝,或者該數(shù)字是7的倍數(shù)脂新,我們打印敲桌子,其余數(shù)字直接打印輸出粗梭。

#include <iostream>
using namespace std;
#include <cmath>

int main()
{
    for (int i = 1; i <= 100; i++)
    {
        if (i % 10 == 7 || i / 10 == 7 || i % 7 == 0)
        {
            cout << "敲桌子" << endl;
        }
        else
        {
            cout << i << endl;
        }
    }
    system("pause");
    return 0;
}

4.2.3 嵌套循環(huán)

作用:在循環(huán)體中再嵌套一層循環(huán)争便,解決一些實際問題

案例:99乘法口訣表

#include <iostream>
using namespace std;

int main()
{
    cout << "9X9乘法口訣表" << endl;
    for (int i = 1; i < 10; i++)
    {
        for (int j = 1; j <= i; j++)
        {
            cout << j << " X " << i << " = " << i*j<<"\t" ;
        }
        cout << endl;
    }
    cout << endl;
    cout << endl;
    cout << "99加法表" << endl;
    for (int i = 1; i < 10; i++)
    {
        for (int j = i; j <10; j++)
        {
            cout << i << " + " << j << " = " << i+j << "\t";
        }
        cout << endl;
    }
    system("pause");
    return 0;
}

4.3 跳轉語句

4.3.1 break語句

作用:用于跳出選擇結構或者循環(huán)結構

break使用時機:

  • 出現(xiàn)switch條件語句中,作用是終止case并跳出switch
  • 出現(xiàn)循環(huán)語句中楼吃,作用是跳出當前的循環(huán)語句
  • 出現(xiàn)在嵌套語句中始花,跳出最近的內存循環(huán)語句

4.3.2 continue語句

作用:在循環(huán)語句中,跳過本次循環(huán)中余下尚未執(zhí)行的語句孩锡,繼續(xù)執(zhí)行下一次循環(huán)

continue并沒有使整個循環(huán)終止酷宵,而break會跳出循環(huán)

4.3.3 goto語句

作用:可以無條件跳轉語句

語法:goto 標記;

解釋:如果標記的名稱存在,執(zhí)行到goto語句時躬窜,會跳轉到標記的位置浇垦。

在程序中不建議使用goto語句,以免造成程序流程混亂

5. 數(shù)組

5.1 概述

所謂數(shù)組荣挨,就是一個集合男韧,里面存放了相同類型的數(shù)據(jù)元素

特點1:數(shù)組中的每個數(shù)據(jù)元素都是相同的數(shù)據(jù)類型

特點2:數(shù)組由連續(xù)的內村位置組成的

5.2 一維數(shù)組

5.2.1 一維數(shù)組定義方式

一維數(shù)組的三種定義方式:

  1. 數(shù)據(jù)類型 數(shù)組名[數(shù)組長度];

  2. 數(shù)據(jù)類型 數(shù)組名[數(shù)組長度] = {值1,值2 ...}

    如果在初始化數(shù)據(jù)的時候默垄,沒有全部填寫完此虑,會用0來填補剩余數(shù)據(jù)

  3. 數(shù)據(jù)類型 數(shù)組名[] = {值1,值2 ...}

數(shù)組元素的下標是從0開始索引的

5.2.2 一維數(shù)組組名

用途:

可以統(tǒng)計整個數(shù)組在內存中的長度

可以獲取數(shù)組在內存中的首地址

數(shù)組名是一個常量口锭,不可以進行賦值操作

練習案例:五只小豬稱體重

案例描述:

在一個數(shù)組中記錄了五只小豬的體重并打印最重的小豬體重

#include <iostream>
using namespace std;

int main()
{
    cout << "請輸入五只小豬體重:" << endl;
    int arr[5];
    for (int i = 0; i < 5; i++)
    {
        cout << "第" << i+1 <<"只豬的體重為";
        cin >> arr[i];
    }
    int max = 0;
    int j = 0;
    int t = 0;
    for (j = 0; j < 5; j++)
    {
        
        if (arr[j] >= max)
        {
            max = arr[j];
            t = j + 1;
        }
    
    }
    cout << "最大值體重為"<< max << endl;
    cout << "第" << t << "只豬最重" << endl;
    system("pause");
    return 0;
}

結果:

案例2:數(shù)組元素逆置

案例描述:請聲明一個5個元素的數(shù)組朦前,并且將元素逆置。

#include <iostream>
using namespace std;

int main()
{
    //1.創(chuàng)建數(shù)組元素逆置
    int arr[5] = {};
    cout << "輸入數(shù)組元素" << endl;
    for (int k = 0; k < 5; k++)
    {
        cout << "第" << k << "個元素為:";
        cin >> arr[k];
    }
    cout << "轉換前的順序為:";
    for (int i = 0; i < 5; i++)
    {
        cout << arr[i] << " ";
    }
    cout << endl;
    //2.實現(xiàn)逆置
    int start = 0;//起始元素下標
    int end = sizeof(arr) / sizeof(arr[0]) - 1;//結束下標
    while (start < end) 
    {
        int temp = arr[start];
        arr[start] = arr[end];
        arr[end] = temp;
        start++;
        end--;
    }
    //3.打印逆置后的數(shù)組
    cout << "轉換后的順序為:";
    for (int j = 0; j < 5; j++)
    {
        cout << arr[j] << " ";
    }
    cout << endl;
    
    system("pause");
    return 0;
}

案列結果:

5.2.3 冒泡排序

作用:最常用的排序算法鹃操,對數(shù)組內元素進行排序

  1. 比較相鄰的元素韭寸。如果第一個比第二個大,就交換它們荆隘。
  2. 對每一對相鄰的元素做同樣的工作恩伺,執(zhí)行完畢后,找到一個最大值
  3. 重復以上步驟椰拒,每次比較次數(shù)-1晶渠,直到不需要比較

5.3 二維數(shù)組

二維數(shù)組就是在一維數(shù)組上凰荚,多加一個維度

5.3.1 二維數(shù)組定義方式

  • 數(shù)據(jù)類型 數(shù)組名[行數(shù)][列數(shù)];
  • 數(shù)據(jù)類型 數(shù)組名[行數(shù)][列數(shù)] = {{數(shù)據(jù)1,數(shù)據(jù)2},{數(shù)據(jù)3,數(shù)據(jù)4}};
  • 數(shù)據(jù)類型 數(shù)組名[行數(shù)][列數(shù)] = {數(shù)據(jù)1褒脯,數(shù)據(jù)2,數(shù)據(jù)3,數(shù)據(jù)4};
  • 數(shù)據(jù)類型 數(shù)組名[][列數(shù)] = {數(shù)據(jù)1浇揩,數(shù)據(jù)2,數(shù)據(jù)3,數(shù)據(jù)4};

利用第二種方式更加直觀,提高代碼可讀性

在定義二維數(shù)組時憨颠,如果初始化了數(shù)據(jù),可以省略行數(shù)

5.3.2 二維數(shù)組名

查看二維數(shù)組所占內存空間

獲取二維數(shù)組首地址

5.3.3 二維數(shù)組應用案例

考試成績統(tǒng)計:

案例描述:有三名同學(張三积锅,李四爽彤,王五),在一次考試中的成績分別如下表缚陷,請分別輸出三名同學的總成績

語文 數(shù)學 英語
張三 100 100 100
李四 90 50 100
王五 60 70 80
#include <iostream>
using namespace std;
#include <string>
int main()
{
    string names[3] = { "張三","李四","王五" };
    int score[3][3] = 
    {
        {100,100,100},
        {90,50,100},
        {60,70,80}
    };
    for (int i = 0; i < 3; i++)
    {
        int sum = 0;
        for (int j = 0; j < 3; j++)
        {
            sum += score[i][j];
        }
        cout << names[i] << "的總分:" << sum << endl;
    }
    system("pause");
    return 0;
}

結果:

代碼地址:https://github.com/smallpotatody/C-_learning/tree/master/day03/code

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末适篙,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子箫爷,更是在濱河造成了極大的恐慌嚷节,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,542評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件虎锚,死亡現(xiàn)場離奇詭異硫痰,居然都是意外死亡,警方通過查閱死者的電腦和手機窜护,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評論 3 394
  • 文/潘曉璐 我一進店門效斑,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人柱徙,你說我怎么就攤上這事缓屠。” “怎么了护侮?”我有些...
    開封第一講書人閱讀 163,912評論 0 354
  • 文/不壞的土叔 我叫張陵敌完,是天一觀的道長。 經常有香客問我羊初,道長滨溉,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,449評論 1 293
  • 正文 為了忘掉前任凳忙,我火速辦了婚禮业踏,結果婚禮上,老公的妹妹穿的比我還像新娘涧卵。我一直安慰自己勤家,他們只是感情好,可當我...
    茶點故事閱讀 67,500評論 6 392
  • 文/花漫 我一把揭開白布柳恐。 她就那樣靜靜地躺著伐脖,像睡著了一般热幔。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上讼庇,一...
    開封第一講書人閱讀 51,370評論 1 302
  • 那天绎巨,我揣著相機與錄音,去河邊找鬼蠕啄。 笑死场勤,一個胖子當著我的面吹牛,可吹牛的內容都是我干的歼跟。 我是一名探鬼主播和媳,決...
    沈念sama閱讀 40,193評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼哈街!你這毒婦竟也來了留瞳?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,074評論 0 276
  • 序言:老撾萬榮一對情侶失蹤骚秦,失蹤者是張志新(化名)和其女友劉穎她倘,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體作箍,經...
    沈念sama閱讀 45,505評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡硬梁,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,722評論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了胞得。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片靶溜。...
    茶點故事閱讀 39,841評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖懒震,靈堂內的尸體忽然破棺而出罩息,到底是詐尸還是另有隱情,我是刑警寧澤个扰,帶...
    沈念sama閱讀 35,569評論 5 345
  • 正文 年R本政府宣布瓷炮,位于F島的核電站,受9級特大地震影響,放射性物質發(fā)生泄漏。R本人自食惡果不足惜继阻,卻給世界環(huán)境...
    茶點故事閱讀 41,168評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望烘绽。 院中可真熱鬧,春花似錦俐填、人聲如沸安接。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,783評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽盏檐。三九已至歇式,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間胡野,已是汗流浹背材失。 一陣腳步聲響...
    開封第一講書人閱讀 32,918評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留硫豆,地道東北人龙巨。 一個月前我還...
    沈念sama閱讀 47,962評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像熊响,于是被迫代替她去往敵國和親恭应。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,781評論 2 354

推薦閱讀更多精彩內容

  • ORA-00001: 違反唯一約束條件 (.) 錯誤說明:當在唯一索引所對應的列上鍵入重復值時耘眨,會觸發(fā)此異常。 O...
    我想起個好名字閱讀 5,312評論 0 9
  • 第四天 數(shù)組【悟空教程】 第04天 Java基礎 第1章數(shù)組 1.1數(shù)組概念 軟件的基本功能是處理數(shù)據(jù)境肾,而在處理數(shù)...
    Java幫幫閱讀 1,598評論 0 9
  • 數(shù)組在程序設計中剔难,為了處理方便, 把具有相同類型的若干變量按有序的形式組織起來奥喻。這些按序排列的同類數(shù)據(jù)元素的集合稱...
    朱森閱讀 3,926評論 2 13
  • 指針是C語言中廣泛使用的一種數(shù)據(jù)類型偶宫。 運用指針編程是C語言最主要的風格之一。利用指針變量可以表示各種數(shù)據(jù)結構环鲤; ...
    朱森閱讀 3,444評論 3 44
  • 一纯趋、基礎知識:1、JVM冷离、JRE和JDK的區(qū)別:JVM(Java Virtual Machine):java虛擬機...
    殺小賊閱讀 2,378評論 0 4