電商專業(yè)學(xué)習(xí)嵌入式軟件開發(fā)第三十天

  • C第四天

今天幾乎練了一天的循環(huán),一直在做題,即便如此,除了有點(diǎn)暈真是讓我對循環(huán)也是相對熟悉了。下午老師才給我們講了一點(diǎn)數(shù)組的內(nèi)容殊橙,還好理解起來沒問題。老師也留了2道練習(xí)我們完成耿币,看題目感覺第二題有難度翠胰。

homework:
1.有一個(gè)袋子,里面有三種顏色的球耀销,白:3 紅:3 黑:6. 從中間取8只球楼眷,共有多少種方案
2.求輸出和為一個(gè)給定整數(shù)的所有組合

for循環(huán)
格式:

       1 ->   2   <-  4
for(表達(dá)式1;表達(dá)式2熊尉;表達(dá)式3)
{               \>   /^
                  3
                 語句
}

原理:先執(zhí)行表達(dá)式1罐柳,通常是給循環(huán)變量賦初值,然后執(zhí)行表達(dá)式2狰住,通常是判斷循環(huán)條件是否成立张吉,成立,則執(zhí)行循環(huán)體語句催植;不成立肮蛹,則結(jié)束循環(huán)。若成立创南,執(zhí)行完循環(huán)體語句之后伦忠,執(zhí)行表達(dá)式3,通常是改變循環(huán)變量的值稿辙,然后繼續(xù)判斷表達(dá)式2是否成立昆码,從此就在2,3,4步中循環(huán)執(zhí)行。直至表達(dá)式2不成立邻储,結(jié)束循環(huán)

例:
for循環(huán)里面的各個(gè)表達(dá)式都可以不寫在括號(hào)里赋咽,但是分號(hào)";"不能少。

練習(xí):求某一個(gè)數(shù)的階乘吨娜。
6!=6*5*4*3*2*1
0!=1;
#include <stdio.h>
void main()
{
    int num,fac=1,count=1;
    printf("求幾的階乘:");
    scanf("%d",&num);
    for(;count<=num;count++)
    {
        fac=fac*count;
    }
    printf("fac:%d\n",fac);
}

練習(xí):有5個(gè)運(yùn)動(dòng)員參加10米短跑脓匿,有人讓他們預(yù)測比賽結(jié)果
A選手說:B第一,我第三
B說:我第二,E第四
C說:我第一萌壳,D第二
D說:C最后亦镶,我第三
E說:我第四,A第一袱瓮。
最后比賽結(jié)果出來了缤骨,每位選手都說對了一半,請編程求出比賽結(jié)果尺借。

#include <stdio.h>
void main()
{
    int A,B,C,D,E;
    for(A=1;A<=5;A++)
        for(B=1;B<=5;B++)
            for(C=1;C<=5;C++)
                for(D=1;D<=5;D++)
                    for(E=1;E<=5;E++)
                        if((B==1)+(A==3)==1 &&
                           (B==2)+(E==4)==1 &&
                           (D==3)+(C==5)==1 &&
                           (C==1)+(D==2)==1 &&
                           (E==4)+(A==1)==1)
                            printf("A:%d B:%d C:%d D:%d E:%d\n",A,B,C,D,E);
}

猴子吃桃:猴子第一天的時(shí)候摘了若干個(gè)桃子绊起,當(dāng)即吃了一半多一個(gè),第二天又吃了剩下的一半多一個(gè)燎斩,以后每天都吃剩下的一半多一個(gè)虱歪,等到第6天想吃桃子的時(shí)候蜂绎,發(fā)現(xiàn)只剩下一個(gè),問第一天一共摘了多少個(gè)桃子笋鄙。

6:1
5:(1+1)*2
4:(day5+1)*2
=>  day前=(day今+1)*2
=>n=(n+1)*2

#include <stdio.h>
void main()
{
    int d,n=1;
    for(d=5;d>=1;d--)
        n=(n+1)*2;
    printf("n=%d\n",n);
}

百錢買百雞:一百塊買一百雞师枣,3/公,2/母,小雞2只/塊。
問:怎樣一百塊錢買一百只雞萧落。

#include <stdio.h>
void main()
{
    int g,m,x;
    for(g=1;g<=33;g++)
        for(m=1;m<=50;m++)
        {
            x=100-g-m;
            if((3*g+2*m+x/2==100) && x%2==0)
            printf("g:%d m:%d x:%d\n",g,m,x);
        }
}

練習(xí):有一個(gè)八層妖塔践美,每一層的妖怪都是上一層的2倍,一共有765個(gè)妖怪找岖,問陨倡,第一層和最后一層分別有多少個(gè)妖怪。

  #include<stdio.h>
  int main()
  {
        int m = 1,n = 1,i,sum;
    while(1)
    {   
        m = n;
        sum = n;
        for(i = 7;i >= 1;i--)
        {
            m = m*2;
            sum = sum+m;
        }
        if(sum == 765)
        {
            printf("m = %d n = %d\n",m,n);
            break;
        }
        n++;
    }
  }

自由落體:有一個(gè)小球從100米的高度自由落下许布,反彈回原高度的一半繼續(xù)落下兴革,以后重復(fù)如此,問:第十次落下的時(shí)候共經(jīng)過多少米蜜唾,然后彈回多高的距離杂曲?

#include <stdio.h>
void main()
{
    float h=100,sum=0,i;
    for(i=1;i<=9;i++)
    {
        h=h/2;
        sum=sum+3*h;
    }
    printf("sum:%.1f h:%.1f\n",sum,h/2);
}

continue:結(jié)束當(dāng)前循環(huán),進(jìn)入下一次循環(huán)

#include <stdio.h>
void main()
{
    int i=1;
    for(;i<=5;i++)
    {
        printf("xxx\n");
        continue;//結(jié)束此次循環(huán)灵妨,進(jìn)行下一次循環(huán)
        printf("vvv\n");
    }
    printf("bbb\n");
}

求1~100的累加值解阅,但是跳過個(gè)位數(shù)為3的數(shù)落竹。

#include <stdio.h>
void main()
{
    int i,sum=0;
    for(i=1;i<=100;i++)
    {
        if(i%10==3)
            continue;
        sum += i;
    }
    printf("sum=%d\n",sum);
}

break;結(jié)束循環(huán)泌霍,轉(zhuǎn)而執(zhí)行循環(huán)后面的語句

#include <stdio.h>
void main()
{
    int i;
    for(i=1;i<=5;i++)
    {
        printf("xxx\n");
        break;//結(jié)束整個(gè)循環(huán),轉(zhuǎn)而執(zhí)行循環(huán)后面的語句
        printf("vvv\n");
    }
    printf("bbb\n");
}

練習(xí):統(tǒng)計(jì)從鍵盤輸入的有效字符的個(gè)數(shù)述召,就是第一個(gè)空格鍵之前的字符朱转,如果沒有空格符,就是回車之前的所有字符积暖。

#include <stdio.h>
void main()
{
    char ch;
    int count=0;
    while((ch=getchar())!='\n')
    {
        if(ch==' ')
            break;
        count++;
    }
    printf("%d\n",count);
}

練習(xí):在日本東京藤为,發(fā)生一起謀殺案,警察經(jīng)過排查夺刑,發(fā)現(xiàn)了真兇是4個(gè)人中的一個(gè)缅疟,經(jīng)過排查得知:
A說:不是我
B:是C
C:是D
D:C在胡說
確定3個(gè)說了真話,一個(gè)人說了假話遍愿,求出誰是真兇存淫。

#include <stdio.h>
void main()
{
    int A,B,C,D;
    int killer;
    for(killer='A';killer<='D';killer++)
    {
        if((killer!='A')+(killer=='C')+
        (killer=='D')+(killer!='D')==3)
            printf("killer:%c\n",killer);
    }
}

乒乓球的問題:中日友誼賽,各出三人沼填,中方代表:a,b,c.
日方代表:x,y,z.現(xiàn)在抽簽決定對手名單桅咆。有人打聽結(jié)果,
a說:他不和x比坞笙, c說:他不和x,z比岩饼。問題:對決名單是什么荚虚?

方法一:
#include <stdio.h>
void main()
{
    int i,j,k; //a,b,c對手
    for(i='x';i<='z';i++)
        for(j='x';j<='z';j++)
            if(i!=j)
                for(k='x';k<='z';k++)
                    if(k!=i && k!=j)
                        if(i!='x' && k!='x' && k!='z' )
                            printf("a-%c\nb-%c\nc-%c\n",i,j,k);
}
方法二:
#include<stdio.h>
int main()
{
  int a,b,c,x,y,z;
    for(a = 'x';a <= 'z';a++)
        for(b = 'x';b <= 'z';b++)
            for(c = 'x';c <= 'z';c++)
                if((a != 'x') && (c != 'x') && (c != 'z') && (a != b) && (a != c) && (b != c))
                    printf("a:%c b:%c c:%c\n",a,b,c);
}

數(shù)組:
定義數(shù)組:type arr[n];
例:int a[5];數(shù)組的名字叫a,有5個(gè)元素,每個(gè)元素都是int類型籍茧。
第一個(gè)元素:a[0]
第二個(gè)元素:a[1]
...
第五個(gè)元素:a[4]
一個(gè)含有n個(gè)元素的數(shù)組版述,數(shù)組中的元素的下標(biāo)號(hào)從0開始,到n-1結(jié)束寞冯,即a[0]表示第一個(gè)元素院水,a[n-1]表示最后一個(gè)元素。

char b[10];

int a=1;
a:
口

int a[5];
a:
1     2     3    4    5
口    口    口    口   口
a[0] a[1] a[2]  a[3] a[4]

特點(diǎn):1.在內(nèi)存中分配一整塊內(nèi)存简十,每個(gè)元素緊緊相鄰存放
2.基于第一點(diǎn)檬某,所以可以快速訪問數(shù)組中的任何一個(gè)元素通過它的下標(biāo)號(hào)。

數(shù)組的賦值:
1.初始化賦值:在定義的時(shí)候賦值
例:int a[5]={1,2,3,4,5};
printf("%d %d %d %d %d\n",a[0],a[1],a[2],a[3],a[4]);

注:1.初始化賦值的時(shí)候后面的元素可以不賦全螟蝙,對應(yīng)整型數(shù)組沒有賦值的元素默認(rèn)為0.
2.定義在函數(shù)里面的數(shù)組恢恼,如果沒有賦值,默認(rèn)每個(gè)元素都是隨機(jī)值胰默,定義在函數(shù)外面的數(shù)組场斑,如果沒有賦值,默認(rèn)為0

2.先定義數(shù)組牵署,再賦值漏隐。
注:數(shù)組,只能在定義它的時(shí)候可以整體訪問一個(gè)數(shù)組奴迅,其他任何時(shí)候都不能夠?qū)σ粋€(gè)數(shù)組整體操作青责,如果想整體訪問一個(gè)數(shù)組,只能通過訪問它的每一個(gè)成員元素實(shí)現(xiàn)取具。

注:內(nèi)存的最小存儲(chǔ)單位是字節(jié)脖隶,每個(gè)字節(jié)都有自己的地址,作為一個(gè)數(shù)組暇检,這么一段連續(xù)內(nèi)存來說产阱,它的最開頭的字節(jié)的地址代表整個(gè)連續(xù)內(nèi)存的地址。一段連續(xù)內(nèi)存的地址就是他的首地址块仆。

練習(xí):求一個(gè)整型數(shù)組int a[10]={1,2,3,4,5,6,7,8,9,10}中的最大值和最小值

#include <stdio.h>
void main()
{
    int a[10]={1,2,3,4,5,6,7,8,9,0},i;
    int max=a[0];
    int min=a[0];
    for(i=1;i<=9;i++)
    {
        if(max<a[i])
            max=a[i];
        if(min>a[i])
            min=a[i];
    }
    printf("max:%d min:%d\n",max,min);
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末构蹬,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子悔据,更是在濱河造成了極大的恐慌庄敛,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,817評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蜜暑,死亡現(xiàn)場離奇詭異铐姚,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,329評論 3 385
  • 文/潘曉璐 我一進(jìn)店門隐绵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來之众,“玉大人,你說我怎么就攤上這事依许」缀蹋” “怎么了?”我有些...
    開封第一講書人閱讀 157,354評論 0 348
  • 文/不壞的土叔 我叫張陵峭跳,是天一觀的道長膘婶。 經(jīng)常有香客問我,道長蛀醉,這世上最難降的妖魔是什么悬襟? 我笑而不...
    開封第一講書人閱讀 56,498評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮拯刁,結(jié)果婚禮上脊岳,老公的妹妹穿的比我還像新娘。我一直安慰自己垛玻,他們只是感情好割捅,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,600評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著帚桩,像睡著了一般亿驾。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上账嚎,一...
    開封第一講書人閱讀 49,829評論 1 290
  • 那天莫瞬,我揣著相機(jī)與錄音,去河邊找鬼醉锄。 笑死乏悄,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的恳不。 我是一名探鬼主播,決...
    沈念sama閱讀 38,979評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼开呐,長吁一口氣:“原來是場噩夢啊……” “哼烟勋!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起筐付,我...
    開封第一講書人閱讀 37,722評論 0 266
  • 序言:老撾萬榮一對情侶失蹤卵惦,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后瓦戚,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體沮尿,經(jīng)...
    沈念sama閱讀 44,189評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,519評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了畜疾。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赴邻。...
    茶點(diǎn)故事閱讀 38,654評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖啡捶,靈堂內(nèi)的尸體忽然破棺而出姥敛,到底是詐尸還是另有隱情,我是刑警寧澤瞎暑,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布彤敛,位于F島的核電站,受9級(jí)特大地震影響了赌,放射性物質(zhì)發(fā)生泄漏墨榄。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,940評論 3 313
  • 文/蒙蒙 一勿她、第九天 我趴在偏房一處隱蔽的房頂上張望渠概。 院中可真熱鬧,春花似錦嫂拴、人聲如沸播揪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,762評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽猪狈。三九已至,卻和暖如春辩恼,著一層夾襖步出監(jiān)牢的瞬間雇庙,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,993評論 1 266
  • 我被黑心中介騙來泰國打工灶伊, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留疆前,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,382評論 2 360
  • 正文 我出身青樓聘萨,卻偏偏與公主長得像竹椒,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子米辐,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,543評論 2 349

推薦閱讀更多精彩內(nèi)容