北京理工計算機 上機複試2001年(1)

一、編寫程序,計算下列分段函數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
2001_01.cpp

二、編寫程序,讀入一個整數 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    
2001_02.cpp

三、 設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
View Code

四、 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 }
2001_04.cpp
相關文章
相關標籤/搜索