1. 程式人生 > >第二學期-第一次作業

第二學期-第一次作業

高級 emp lan 元素 input 圖片 sum bubuko ron

C高級第一次PTA作業(1)

技術分享圖片

1. 計算兩數的和與差

1.設計思路

第一步:設出被調用函數 op1, op2, *psum, *pdiff ,利用被調函數計算*psum的值和*pdiff的值;

第二步:代入到主函數就是計算a、b的和與差;

第三部:對所得到數值進行輸出;

2.流程圖

技術分享圖片技術分享圖片

3.插入代碼

1 void sum_diff( float op1, float op2, float *psum, float *pdiff )
2 {
3   *psum = op1 + op2;
4   *pdiff = op1 - op2;
5 }

4.本題調試中遇到的問題:

未遇到問題;

2. 拆分實數的整數與小數部分

1.設計思路

第一步:根據主函數,設出被調用函數x, *intpart, *fracpart ,計算出*intpart的值、*fracpart的值;

第二步:主函數中輸入函數x、fracpart,並且輸入x的值,利用被調函數得出intpart和fracpart的值;

第三步:對所得到數值進行輸出;

2.流程圖

技術分享圖片技術分享圖片

3.插入代碼

1 void splitfloat( float x, int *intpart, float *fracpart )
2 {
3   *intpart = (int)x;
4   *fracpart = x - *intpart;
5 }

C高級第一次PTA作業(2)

技術分享圖片

1 .在數組中查找指定元素

1.設計思路

第一步:利用主調函數設出被調函數list[], n, x,定義i、index、n、x為整形,輸入n;

第二步:利用for循環輸入a[i],調用被調函數確定index的值;

第三步:被調函數中,設j、q,為整形,利用for循環,尋找是否有x = list[j],如果有,則使q = j,如果沒有,則q= -1;

第四步:利用if條件句,輸出結果;

2.流程圖

技術分享圖片技術分享圖片

3.插入代碼

 1     int search( int list[], int n, int x )
 2     {
 3         int j,q=-1;
 4         for
(j=0;j<n;j++) 5 { 6 if(x==list[j]) 7 { 8 q=j; 9 break; 10 } 11 } 12 return(q); 13 }

2 .找最大值及其下標

1.設計思路

第一步:N =10,根據主調函數寫出被調函數*a、*b、n,設q和j、q=a[0];

第二步:利用for循環查出是否有q < a[j],如果有,則把a[i]的值賦給q,j的地址賦給b;

第三步:另a[N]、i、max、p為整形,設p = 0;利用for循環輸入a[i]的值,根據被調用函數比較出a、&p、N的最大值;

第四步:輸出所得的最大值和p的值。

2.流程圖

技術分享圖片技術分享圖片

3.插入代碼

 1 int fun(int *a,int *b,int n)
 2 {
 3         int q = a[0];
 4         int j;
 5         for(j=0;j<n;j++)
 6         {
 7             if(q < a[j])
 8             {
 9                 q = a[j];
10                 *b = j;
11             }
12         }
13         return(q);
14     }

C高級第一次PTA作業(3)

技術分享圖片

1 .最小數放前最大數放後

1.設計思路

最重要的是被調函數的填寫

第一步: 設出三個被調用函數,input(int*arr,int n)函數輸入n個元素到arr中。

另i為整形,利用for循環在a[i]中輸入10個新的元素。

第二步:max_min(int *arr, int n)函數求指針arr所指向的一維數組中的最大值和最小值,其中最小的數與第一個數對換,將最大的數與最後一個數對換。

設最小的元素和最大的元素都為a[0],令 i,temp,int ,q,w為整形,其中q= 0,w = 0;利用for循環把最大值和最小值進行賦值,q, w分別為最小值和最大 值的下標。把所查找出的最大的下標與為加入數據前最大的數進行交換,把a[w]與a[rr+n-1]交換,同理,把a[p]與a[arr+0]作交換。

第三步:output(int*arr,int n)在一行中輸出數組元素,每個元素輸出占3列。使i為整形,利用for循環輸出a[arr+i]的值。

2.流程圖

input(int*arr,int n) max_min(int *arr, int n) output(int*arr,int n)

 

 

 

第二學期-第一次作業