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)的代碼行數和時間、博客字數和時間: