一、編寫程序,計算下列分段函數y=f(x)的值。ios
y= -x+2.5 0<= x <2編程
y=2-1.5(x-3)(x-3) 2<= x <4ide
y=x/2-1.5 4<= x <6函數
1 #include<iostream> 2 using namespace std; 3 4 int main(){ 5 double x=0; 6 cout<<"please input a num 0-6:"<<endl; 7 cin>>x; 8 if(x<0||x>=6){ 9 cout<<"輸入不合法"<<endl; 10 return 0; 11 } 12 13 if(0<=x&&x<2) 14 cout<<"y=-x+2.5 x= "<<x<<"y= "<<2.5-x<<endl; 15 else if(x<4) 16 cout<<"y=2-1.5(x-3)(x-3) x= "<<x<<"y= "<<2-1.5*(x-3)*(x-3)<<endl; 17 else 18 cout<<"y=x/2-1.5 x= "<<x<<"y= "<<x/2.0-1.5<<endl; 19 20 return 0; 21 }//main
二、編寫程序,讀入一個整數 N。若 N 爲非負數,則計算 N 到 2N 之間的整數和;若 N 爲一個負數,則求 2N 到 N 之間的整數和。spa
1 #include<iostream> 2 using namespace std; 3 4 int main(){ 5 6 int n; 7 cout<<"please input an integer:"<<endl; 8 cin>>n; 9 if(n>=0) 10 cout<<(n+2*n)*(n+1)/2<<endl; 11 else 12 cout<<(n+2*n)*(1-n)/2<<endl; 13 14 return 0; 15 }//main
三、 設N是一個四位數,它的 9 倍剛好是其反序數(例如:1234的反序數是4321),求N的值。code
1 #include<iostream> 2 using namespace std; 3 4 int main(){ 5 int n; 6 int reverse=0; 7 for(n=1000;n<10000;++n){ 8 reverse=(n%10)*1000+(n%100)/10*100+(n%1000)/100*10+(n%10000)/1000; 9 if(9*n==reverse){cout<<n<<endl; 10 cout<<"9n="<<9*n<<endl; 11 cout<<"re="<<reverse<<endl;} 12 } 13 return 0; 14 }//main
四、 N我的圍成一圈順序編號,從1號開始按一、二、3順序報數,報3者退出圈外,其他的人再從一、二、3開始報數,報3的人再退出圈外,依次類推。請按退出順序輸出每一個退出人的原序號。要求使用環行鏈表編程。blog
1 #include<iostream> 2 #include<stdlib.h> 3 using namespace std; 4 5 6 struct factor{ 7 factor* front; 8 int order; 9 factor* next; 10 }; 11 struct fs{ 12 factor* first; 13 factor* last; 14 int count; 15 }; 16 17 int main(){ 18 int n; 19 cout<<"please input a number"<<endl; 20 cin>>n; 21 fs* list=(fs*)malloc(sizeof(fs)); 22 list->count=0; 23 list->first=NULL; 24 list->last=NULL; 25 26 for(int i=1;i<=n;++i){ 27 factor* f=(factor*)malloc(sizeof(factor)); 28 f->front=NULL; 29 f->next=NULL; 30 f->order=i; 31 if(list->first==NULL){ 32 f->front=f; 33 f->next=f; 34 list->first=f; 35 list->last=f; 36 } 37 else{ 38 f->front=list->last; 39 f->next=list->first; 40 list->last->next=f; 41 list->last=f; 42 list->first->front=f; 43 } 44 list->count++; 45 } 46 47 factor* f=list->first; 48 for(int j=1;list->count>0;j++){ 49 factor* d=f; 50 f=f->next; 51 52 if(j%3==0){ 53 list->count--; 54 55 d->front->next=d->next; 56 d->next->front=d->front; 57 cout<<d->order<<" "; 58 free(d); 59 } 60 61 } 62 63 64 return 0; 65 }