循環(huán)for()-西安交通大學、看_第1頁
循環(huán)for()-西安交通大學、看_第2頁
循環(huán)for()-西安交通大學、看_第3頁
循環(huán)for()-西安交通大學、看_第4頁
循環(huán)for()-西安交通大學、看_第5頁
已閱讀5頁,還剩38頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

西安交通大學計算機教學實驗中心

20131第3章運算的流程控制計算機程序設(shè)計(C++)內(nèi)容提要2程序的執(zhí)行順序循環(huán)分支3.1程序的執(zhí)行順序3C++程序從main函數(shù)開始,按順序逐行執(zhí)行每一條語句。程序的執(zhí)行是有順序的從上到下,如果不是循環(huán),執(zhí)行過的不會反復??!兩類語句可以控制方向循環(huán),可以有條件地重復執(zhí)行某些語句分支,可以有選擇地跨過某些語句3.2不同情況分別處理——分支不同情況,分別處理特殊情況,特殊處理3.3.1

特殊情況特殊處理(單路分支)...if

(<條件>){<if塊>}...條件語句塊truefalse語句塊語句塊分程序,局部變量4【例3-1】用戶用戶輸入量個數(shù),求它們的最大值?!舅惴ā吭O(shè)a,b表示輸入的兩個數(shù),max表示最大值①輸入a,b;②max=a③如果b>max,則max=b④max。問題擴展編程求三個數(shù)的最大數(shù)。編程計算下列分段函數(shù)的值53.3.2

不同情況分別處理(兩路分支)【例3-4】解一元二次方程。輸入一元二次方程的a,b,c三個系數(shù),解一元二次方程ax2+bx+c=0;輸出兩個根(含復根)?!締栴}分析】a=0?6b=0?Δ>0?

Δ=0Δ<0?【算法】8輸入a,b,c;如果a=0,如果b=0,輸出“輸入的系數(shù)不構(gòu)成方程”;否則(即b≠0)計算單根x=-c/b輸出單根x否則(即a≠0)計算delta=b*b-4*a*c如果delta>=0delta=sqrt(delta)輸出x1=(-b+delta)/2a和x2=(-b-delta)/2a否則delta=sqrt(-delta)輸出f復根:x1=-b/2a+j*delta/2a;x2=-b/2a-j*delta/2a(注意j是虛數(shù)單位)結(jié)束9//例3-2解一元二次方程#include

<iostream>

//包含需要的頭文件#include<cmath>

//求根函數(shù)sqrt需要的頭文件using

namespace

std;

//名字空間int

main()//主函數(shù){double

a,b,c;//定義變量保存系數(shù)

double

delta;//表示根的判別式

double

x,x1,x2;//表示根cout<<"請輸入一元二次方程的三個系數(shù)a,b,c:";//顯示提示信息

cin>>a>>b>>c;//輸入一元二次方程的系數(shù)if(a==0)//二次項系數(shù)a等于0的情況{if(b==0)//一次項系數(shù)也等于0,不是方程{cout<<"輸入的系數(shù)不構(gòu)成方程"<<endl;}else//二次項系數(shù)等于0,一次項系數(shù)不為0,一元一次方程{x=-c/b;//計算單根cout<<"實際為一元一次方程,根為"<<x<<endl;//輸出}}else//二次項系數(shù)a不為0的情況{delta=b*b-4.0*a*c;//計算判別式的值

if(delta>=0)//判別式大于等于0,有實根{delta=sqrt(delta);//判別式開方

x1=(-b+delta)/2.0/a;//根1x2=(-b-delta)/2.0/a;//根2cout<<"方程有實根,它們是:"<<endl;//顯示根

cout<<"x1="<<x1<<",x2="<<x2<<endl;//}else//判別式小于0,有復根【源程序】p6110【程序測試】11要檢驗程序的正確性,還應(yīng)設(shè)計哪些測試用例?問題擴展算法的重要性算法與程序的關(guān)系復數(shù)的構(gòu)造if的嵌套,語句的嵌套3.2.3多種情況分類處理(多重分支switch)12【例3-3】編程實現(xiàn)一個簡單的計算器功能,實現(xiàn)簡單的加、減、乘、除表達式式的計算。設(shè)用戶輸入的表達式具有如下格式:<操作數(shù)1>

<運算符>

<操作數(shù)2>其中的操作數(shù)是整數(shù)或?qū)崝?shù),運算符是“+”、“-”、

“*”或“/”之一,三個量之間用空格隔開。問題分析輸入

3

+

5 輸出9輸入

3

*

5 輸出15如果 運算符不同,操作就不同if語句可以實現(xiàn)嗎?switch語句的格式switch(<表達式>){case<常量表達式1>:<case塊1>case<常量表達式2>:<case塊2>...case<常量表達式n>:<case塊n>default:<默認case塊>}13關(guān)鍵詞:<表達式>的數(shù)據(jù)類型:整型、字符、邏輯、枚舉defaultbreak【算法描述】14用num1,num2,op分別表示輸入的表達式的兩個操作數(shù)和一個運算符。如果op="+",則result=num1+num2,輸出result;如果op="-",則result=num1-num2,輸出result;如果op="*",則result=num1*num2,輸出result;如果op="/",則如果num2=0,顯示“除數(shù)為0”;否則,計算result=num1/num2,輸出result;其他,顯示“運算符錯誤”?!驹闯绦颉縫6315【源程序】p63–輸出信息用字符串表示(字符數(shù)組)–信息的表達–數(shù)據(jù)的輸入–信息處理–數(shù)據(jù)輸出測試指南3.3多次加工——循環(huán)程序設(shè)計163.3.1

已知次數(shù)的循環(huán)for(<變量>=<初始值表達式>;<循環(huán)條件>;<增量>){<循環(huán)體>}例如int

i=0,n=10,sum=0;for(i=0;i<n;i++){sum=sum+i;}

//結(jié)果?

分程序,局部變量for的一般形式for語句更一般的形式為:for(<表達式1>;<表達式2>;<表達式3>){<循環(huán)體>}表達式可以省略(不推薦)for(;;){<循環(huán)體>}17//example3-4

求n個數(shù)的和及平均值#include<iostream>//包含輸入輸出頭文件

using

namespace

std;//指定名字空間int

main()//主函數(shù){int

n;//聲明變量,表示元素個數(shù)double

x,sum,average;//聲明變量,表示輸入的數(shù),和,平均值

int

i;//循環(huán)變量sum=0;//和置初始值

average=0;//平均值置初始值

cout<<"請輸入元素個數(shù):";cin>>n;//輸入元數(shù)個數(shù)for(i=0;i<n;i++)//循環(huán),n次{cout<<"請輸入第"<<i+1<<"個元素:";//提示信息

cin>>x;//輸入一個數(shù)sum=sum+x;//求和}average=sum/n;//計算平均值

cout<<"The

sumis"<<sum<<endl;cout<<"The

average

is"<<average<<endl;return

0;//函數(shù)返回}【例3-4】編寫程序,計算n個數(shù)的和及平均值。n的值和n個數(shù)由用戶輸入?!締栴}分析】【算法描述】用n表示數(shù)據(jù)個數(shù),x表示某個元素,

sum表示和,average表示平均值。①n=0,sum=0;average=0;②輸入n③對i=1,...,n④⑤輸入x計算sum=sum+x⑥average=sum/n⑦輸出sum及average。18問題擴展①請編程計算1+2+3+...+n。②計算n!。③計算兩個n維向量的夾角。設(shè)是兩個n維向量,計算它們的夾角。要求程序循環(huán)提示用戶輸入向量并進行計算。19【算法】計算向量的夾角。設(shè)向量用數(shù)組a[N]b[N]表示。①輸入兩個向量;②計算a,b的內(nèi)積innerproduct:innerproduct=0對i=0,...,n-1計算innerproduct=innerproduct+a[i]*b[i]③計算a,b的模modea,modeb;④計算cosinetheta=innerproduct/modea/modeb計算theta=arccosin(cosinetheta)⑥輸出theta⑦轉(zhuǎn)①20for(;;)

//循環(huán),不斷接受用戶輸入并計算向量的夾角{cout<<"請輸入向量的維數(shù)(n>0):";//提示cin>>n;

//輸入向量的實際維數(shù)cout<<"請輸入向量a:";

//提示for(i=0;i<n;i++)

//輸入向量a,逐個輸入其元{

cin>>a[i];cout<<"請輸入向量b:";for(i=0;i<n;i++)}//輸入向量b,逐個輸入其元{

cin>>b[i];

}22//變量賦初始值,開始為innerproduct=0;modea=0;modeb=0;for(i=0;i<n;i++)//逐步求和,加n次{

innerproduct=innerproduct+a[i]*b[i];//內(nèi)積modea=modea+a[i]*a[i];modeb=modeb+b[i]*b[i];//向量a的模的平方//向量b的模的平方}modea=sqrt(modea);modeb=sqrt(modeb);//開方,得a的模//開方,得b的模cosinetheta=innerproduct/modea/modeb;

//夾角余theta=acos(cosinetheta);theta=theta/PAI*180;//夾角弧度//夾角度cout<<"它們的夾角為:"<<theta<<endl;

//顯示}return

0;

}//會進入下一循環(huán)233.3.2依據(jù)條件進行循環(huán)1.當型循環(huán)while(<循環(huán)條件>){<循環(huán)體>}2.直到型循環(huán)do{<循環(huán)體>}while(<循環(huán)條件>);24【例3-5】計算e的近似值。數(shù)學上,證明的極限是存在的,記為e。對函數(shù)ex作泰勒展開,當

x=1時編程計算e的近似值,當最后一項小于10-15時停止計算。輸出保留到小數(shù)點后16位。25【問題分析】階乘如何計算?通項如何計算?如何求和?如何保留小數(shù)點后16位?26【算法描述】27①用e表示“e”的近似值,u表示通項,n表示項的序號,初時:e=1,u=1,n=1②計算新通項u=u/n;加到近似解e中:e=e+u;構(gòu)造下一項的分母n:n=n+1;③若u>=1.0e-15,轉(zhuǎn)②。(滿足某條件時轉(zhuǎn)到前面某步,就環(huán))④輸出e?!驹闯绦颉?8#include

<iostream>using

namespace

std;//包含需要的頭文件//名字空間intmain()

//主函數(shù){double

e,u,n;//定義變量,表示e,通項,通項分母e=1;u=1;n=1;//e的初始值//通項初始值//通項分母初始值cout.setf(ios::fixed);cout.precision(20);數(shù)位//定點顯示//精度,與上句結(jié)合,小數(shù)點后do{u=u/n;

//構(gòu)造新通項e=e+u;

//加到近似值中n++;

//新通項的分母cout<<e<<endl;

//顯示當前的近似值}while(u>1.0E-15);//不滿足精度時循環(huán)return

0;}【思考題】上述循環(huán)可以用while,for嗎?如何用?29#

include

<iostream>using

namespace

std;int

main(){char

s[100]="abc";int

n=0;n=0;while(s[n]!=0){n++;};cout<<"length="<<n<<endl;n=0;do

{n++;}while(s[n]!=0);cout<<"length="<<n<<endl;return

0;}while{}和do{}while();--求字符串的長度#

include

<iostream>using

namespace

std;int

main(){char

s[100]="";int

n=0;//

while(1){//cin>>s;n=0;while(s[n]!=0){

n++;

}cout<<"length="<<n<<endl;}return

0;}#

include

<iostream>using

namespace

std;int

main(){char

s[100]="b";int

n=0;n=0;do{n++;}while(s[n]!=0);cout<<"length="<<n<<endl;return

0;}303.3.3

終止循環(huán)和直接進入下次循環(huán)31【3-6】編程計算一個實數(shù)的任意次方根。用戶輸入一個實數(shù)x和開方的次數(shù)n,顯示方根,如用戶輸入23

,顯示2的三次方根1.25992。要求當用戶輸入0

0時程序結(jié)束,用戶輸入x<0且n<=0時或x<=0且1/n不為整數(shù)時顯示“輸入錯誤”的提示并繼續(xù)輸入。【源程序】//example3-6

計算x的任意次方根

#include<iostream>//包含輸入輸出頭文件

#include<cmath>using

namespace

std;//指定名字空間

int

main()//主函數(shù){double

x;double

n;while(1)

//一直循環(huán){cin>>x>>n;if(x==0

&&

n==0)//終止條件{cout<<"Programterminated"<<endl;break;

//跳出最近循環(huán)}elseif((x<0

&&

n<=0)||(x<=0

&&

1/n!=int(1/n)))//錯誤條件{cout<<"error

reinput"<<endl;continue;

//直接進入下一個循環(huán)}cout<<x<<"\t"<<n<<"th

root

"<<pow(x,1.0/n)<<endl;}return

0;//函數(shù)返回}【算法描述】求x 的n次方根32循環(huán)進行下列計算輸出提示信息“本程序計算x的n次方根,請輸入x,n”輸入x,n如果x==0并且n==0break如果(x<0并且n<=0)或(x<=0且1/n不為整數(shù))輸出錯誤信息“輸入錯誤,”直接進入下一次循環(huán)y=pow(x,1/n);輸出y3.4綜合實例333.4.1數(shù)組的輸入、排序和輸出【例3-6】冒泡排序。用戶從鍵盤輸入N,然后輸入N個實數(shù),使用冒泡排序方法對這N個元素排序,輸出排序后的數(shù)據(jù)?!締栴}分析】數(shù)組元素的輸入?冒泡排序?數(shù)組元素的輸出【算法描述】34設(shè)有N個元素,用數(shù)組a[i]表示,i=0,...,N①輸入N;②輸入a[i],i=0,...,N-1;③對i=1,...,n-2④⑤對j=0,...,n-2-i若a[j]>a[j+1],則交換它們的值。–⑥對i=0,...,N-1,輸出a[i]?!驹闯绦颉縫73問題擴展35用戶不提前輸入元素個數(shù),自動判斷用戶的輸入結(jié)束?輸出數(shù)組元素,每行5個?3.4.2字符串的處理36輸入、輸出、文字編輯、搜索引擎【例3-7】文字信息統(tǒng)計。用戶輸入一段文本(英文),統(tǒng)計其字符總個數(shù),大寫字母個數(shù)、小寫字母個數(shù)、數(shù)字個數(shù)及其他字符個數(shù)。問題分析字符串的輸入?統(tǒng)計結(jié)束?輸出算法描述37設(shè)字符串用str[100]表示,str[i]表示第i+1個字符(從1開始)。用len表示字符串長度,capital表示大寫字母個數(shù),smallletter表示小寫字母個數(shù),

digit表示數(shù)字個數(shù),others表示其他字母個數(shù),初始時它們的值均為0。①輸入字符串;②i=0;③如果str[i]=’\0’,轉(zhuǎn)⑥;否則執(zhí)行④;④

len=len+1如果str[i]為大寫字母capital++;否則如果str[i]為小寫寫字母smallletter++;否則如果str[i]為數(shù)字digit++;否則others++i=i+1,轉(zhuǎn)③;⑥輸出統(tǒng)計數(shù)據(jù)。38【例3-6】尋找自冪數(shù)。用戶輸入位數(shù)n,找出并顯示出所有n位的自冪數(shù)?!締栴}分析】分離各位40//例3-8自冪數(shù)#include

<iostream>

//包含需要的頭文件#include<cmath>

//數(shù)學函數(shù)需要的頭文件using

namespace

std;

//名字空間int

main(){int

n;//表示數(shù)的位數(shù)int

start,end;//表示n位數(shù)的起始值和終止值

int

m;//待分解各位的數(shù),即待判斷的數(shù)

int

digit;//某個數(shù)位的值int

sum;//各位數(shù)的n次方的和,每個數(shù)在檢驗開始前要賦0int

i;//循環(huán)變量,待檢驗的數(shù)cout<<"求n位自冪數(shù),請輸入位數(shù):";//提示信息

cin>>n;//輸入位數(shù)while(n>0)//大于0時計算{start=pow(10,n-1);//n位數(shù)的起始值

end=pow(10,n)-1;//n位數(shù)的終止值

cout<<n<<"位自冪數(shù):";//輸出說明信息for(i=start;i<=end;i++)//從“起始值”到“終止值”逐個檢驗{m=i;//因為檢驗過程會破壞該數(shù),而后還要使用,所以將i賦給m//檢驗過程中m的值會改變,而i的值不變。sum=0;//各位數(shù)的n次方和,檢驗前賦0while(m!=0)//m不為0時檢驗,m開始為待檢驗的數(shù),隨著取各位數(shù)字,其值改變{digit=m%10;//取最低位數(shù)字,第1次是原數(shù)的各位,第2次為原數(shù)的十位

sum=sum+pow(digit,n);//n次方,再求和m=m/10;//去掉個位,剛才的十位成為新個位}//上面的循環(huán)結(jié)束時sum就是各位數(shù)字的n次方的和

if(sum==i)//邏輯表達式的值為true時,表示是自冪數(shù){【算法分析】①輸入位數(shù)n。②計算n位數(shù)的起始值和終止值⑥d=m%10,sum=sum+dn,start=10n-1end=10n-1i=start⑦m=m/10轉(zhuǎn)⑤如果sum=i,顯示i。③如果i>end轉(zhuǎn)⑨。⑧i=i+1,轉(zhuǎn)③④

m=i,sum=0⑨結(jié)束。⑤如果m=0,轉(zhuǎn)⑦。41【源程序】42

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論