第一次作業


6-1拆分實數的整數與小數部分

1.設計思路

(1)第一步:根據已知題意,觀察已給程序,了解題中各個參數的意義。

第二部;設計簡單的函數,執行題中所需功能。

第三部:上機運行程序,檢查程序對錯。

(2)流程圖

2.實驗代碼

#include <stdio.h>

void splitfloat( float x, int *intpart, float *fracpart );

int main()
{
    float x, fracpart;
    int intpart;

    scanf("%f", &x);
    splitfloat(x, &intpart, &fracpart);
    printf("The integer part is %d\n", intpart);
    printf("The fractional part is %g\n", fracpart);

    return 0;
}
void splitfloat( float x, int *intpart, float *fracpart )
{
 *intpart=(int)x;
 *fracpart=x-*intpart;}
  
  

3.本體調試過程碰到問題及解決辦法

錯誤信息1:無

錯誤原因1:無  

git地址:https://coding.net/u/chongjing79/p/diyicizuoye/git/upload/master/?public=trueg

 

題目6-2 在數組中查找指定元素

1.設計思路

(1)第一步:根據已知題意,觀察已給程序,了解題中各個參數的意義。

第二部;設計簡單的函數,執行題中所需功能。

第三部:上機運行程序,檢查程序對錯。

(2)流程圖

2.實驗代碼

#include <stdio.h>
#define MAXN 10

int search( int list[], int n, int x );

int main()
{
    int i, index, n, x;
    int a[MAXN];

    scanf("%d", &n);
    for( i = 0; i < n; i++ )
        scanf("%d", &a[i]);
    scanf("%d", &x);
    index = search( a, n, x );
    if( index != -1 )
        printf("index = %d\n", index);
    else
        printf("Not found\n");

    return 0;
}
int search( int list[], int n, int x )
{ int i;
 for(i=0;i<n;i++)
{ if (x==list[i])
  return i;
  
} 
  return -1;
}

3.本體調試過程碰到問題及解決辦法

錯誤信息1:出現查找的元素不對

錯誤原因1:忘記下標應該減一

git地址:https://coding.net/u/chongjing79/p/zuoye2/git/blob/master/6.2cpp.cpp?public=true


題目6-3 計算兩數的和與差

1.設計思路

(1)第一步:根據已知題意,觀察已給程序,了解題中各個參數的意義。

第二部;設計簡單的函數,執行題中所需功能。

第三部:上機運行程序,檢查程序對錯。

(2)流程圖

2.實驗代碼

#include <stdio.h>

void sum_diff( float op1, float op2, float *psum, float *pdiff );

int main()
{
    float a, b, sum, diff;

    scanf("%f %f", &a, &b);
    sum_diff(a, b, &sum, &diff);
    printf("The sum is %.2f\nThe diff is %.2f\n", sum, diff);
    
    return 0; 
}
void sum_diff( float op1, float op2, float *psum, float *pdiff )
{*psum = op1+op2;
*pdiff = op1-op2;
  
}

3.本體調試過程碰到問題及解決辦法

錯誤信息1:無

錯誤原因1:無  

git地址:https://coding.net/u/chongjing79/p/zuoyer6.3/git/blob/master/6.3.cpp?public=true

 

題目7-1 數組元素循環右移問題

1.設計思路

(1)第一步:根據已知題意,觀察已給程序,了解題中各個參數的意義。

第二部;設計簡單的函數,執行題中所需功能。

第三部:上機運行程序,檢查程序對錯。

(2)流程圖

2.實驗代碼

#include <stdio.h>
#include <stdlib.h>

void aaa(int a[], int size)
{
    int i, t;

    t = a[size-1];

    for(i = size - 2; i >= 0; i--)
    {
        a[i+1] = a[i]; 
    }
    a[0] = t;
}

void ppp(int a[], int size)
{
    int i;

    for(i = 0; i < size; i++)
    {
        printf(i == size-1 ? "%d" : "%d ", a[i]);
    }
}

int main(void)
{
    int array[100];
    int i, N, M;

    scanf("%d %d", &N, &M);
    for(i = 0; i < N; i++)
        scanf("%d", &array[i]);

    for(i = 0; i < M; i++)
    {
        aaa(array, N);
    }

    ppp(array, N);

    return 0;}

3.本體調試過程碰到問題及解決辦法

錯誤信息1:導致后面往前移動的元素不正確

錯誤原因1:  后面的元素沒有另存,導致現在取的地址錯誤

git地址:https://coding.net/u/chongjing79/p/zuoye7.1/git/blob/master/7.1.cpp?public=true

這兩周來所有PTA作業中題目所使用的知識點:

1.地址和指針的概念

2.數組與指針的關系

3.多維數組與指針

4.函數的引用

請用表格和折線圖呈現你本周(3/513:00~3/19 8:00)的代碼行數和時間、博客字數和時間:

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM