學(xué)完C語言之后,我就去閱讀《C Primer Plus》這本經(jīng)典的C語言書籍,對每一章的編程練習(xí)題都做了相關(guān)的解答,僅僅代表著我個人的解答思路,如有錯誤,請各位大佬幫忙點出!
1.設(shè)計一個函數(shù)min(x, y),返回兩個double類型值的較小值。在一個簡單 的驅(qū)動程序中測試該函數(shù)。
#include <stdio.h>
double Min(double x, double y)
{
return x > y ? y : x;
}
int main(void)
{
double min_num = Min(20.0, 15.0);
printf("min_num : %lf\n", min_num);
min_num = Min(15.0, 20.0);
printf("min_num : %lf\n", min_num);
return 0;
}
2.設(shè)計一個函數(shù)chline(ch, i, j),打印指定的字符j行i列。在一個簡單的驅(qū) 動程序中測試該函數(shù)。
#include <stdio.h>
void chline(char ch, int i, int j)
{
for (int m = 0; m < i; m++)
{
for (int n = 0; n < j; n++)
{
printf("%c ", ch);
}
printf("\n");
}
}
int main(void)
{
char ch = '0';
int i = 0, j = 0;
printf("請輸入一個字符:");
scanf("%c",&ch);
printf("請輸入行數(shù):");
scanf("%d", &i);
printf("請輸入列數(shù):");
scanf("%d", &j);
chline(ch, i, j);
return 0;
}
3.編寫一個函數(shù),接受3個參數(shù):一個字符和兩個整數(shù)。字符參數(shù)是待 打印的字符,第1個整數(shù)指定一行中打印字符的次數(shù),第2個整數(shù)指定打印指 定字符的行數(shù)。編寫一個調(diào)用該函數(shù)的程序。
#include <stdio.h>
void chline(char ch, int i, int j)
{
for (int m = 0; m < j; m++)
{
for (int n = 0; n < i; n++)
{
printf("%c ", ch);
}
printf("\n");
}
}
int main(void)
{
char ch = '0';
int i = 0, j = 0;
printf("請輸入一個字符:");
scanf("%c",&ch);
printf("請輸入一行中打印字符的個數(shù):");
scanf("%d", &i);
printf("請輸入指定打印字符的個數(shù):");
scanf("%d", &j);
chline(ch, i, j);
return 0;
}
4.兩數(shù)的調(diào)和平均數(shù)這樣計算:先得到兩數(shù)的倒數(shù),然后計算兩個倒數(shù) 的平均值,最后取計算結(jié)果的倒數(shù)。編寫一個函數(shù),接受兩個double類型的 參數(shù),返回這兩個參數(shù)的調(diào)和平均數(shù)。
#include <stdio.h>
double Reconcile_the_average(double d1, double d2)
{
return 1.0 / ((1.0 / d1 + 1.0 / d2) / 2.0);
}
int main(void)
{
double ret = Reconcile_the_average(3.0,4.0);
printf("ret : %lf\n", ret);
ret = Reconcile_the_average(4.0, 5.0);
printf("ret : %lf\n", ret);
return 0;
}
5.編寫并測試一個函數(shù)larger_of(),該函數(shù)把兩個double類型變量的值替 換為較大的值。例如, larger_of(x, y)會把x和y中較大的值重新賦給兩個變 量。
#include <stdio.h>
void larger_of(double* d1,double* d2)
{
if (*d1 > *d2)
*d2 = *d1;
else
*d1 = *d2;
}
int main(void)
{
double d1 = 1.0, d2 = 2.0, d3 = 3.0,d4 = 4.0;
printf("d1 = %lf,d2 = %lf d3 = %lf,d4 = %lf\n", d1, d2, d3, d4);
larger_of(&d1, &d2);
larger_of(&d3, &d4);
printf("d1 = %lf,d2 = %lf d3 = %lf,d4 = %lf\n", d1, d2, d3, d4);
return 0;
}
6.編寫并測試一個函數(shù),該函數(shù)以3個double變量的地址作為參數(shù),把最 小值放入第1個函數(shù),中間值放入第2個變量,最大值放入第3個變量。
#include <stdio.h>
void sort(double* d1, double* d2, double* d3)
{
double temp = 0.0;
if (*d1 > *d2)
{
temp = *d1;
*d1 = *d2;
*d2 = temp;
}
if (*d1 > *d3)
{
temp = *d1;
*d1 = *d3;
*d3 = temp;
}
if (*d2 > *d3)
{
temp = *d2;
*d2 = *d3;
*d3 = temp;
}
}
int main(void)
{
double d1 = 2.0, d2 = 3.0, d3 = 1.0;
printf("排序前:d1 = %lf,d2 = %lf,d3 = %lf\n", d1, d2, d3);
sort(&d1, &d2, &d3);
printf("排序后:d1 = %lf,d2 = %lf,d3 = %lf\n", d1, d2, d3);
return 0;
}
7.編寫一個函數(shù),從標(biāo)準(zhǔn)輸入中讀取字符,直到遇到文件結(jié)尾。程序要 報告每個字符是否是字母。如果是,還要報告該字母在字母表中的數(shù)值位 置。例如,c和C在字母表中的位置都是3。合并一個函數(shù),以一個字符作為 參數(shù),如果該字符是一個字母則返回一個數(shù)值位置,否則返回-1。
#include <stdio.h>
#include <ctype.h>
int position(char ch)
{
if (islower(ch))
return ch - 'a' + 1;
else if (isupper(ch))
return ch - 'A' + 1;
return -1;
}
void get_char_pos(void)
{
char ch = '0';
printf("請輸入一些字符:");
while ((ch = getchar()) != EOF)
{
if (ch == '\n')
continue;
if (position(ch) != -1)
printf("該字符是一個字母,且位于字母表第%d位\n", position(ch));
else
{
printf("該字符不是一個字母\n");
}
}
}
int main(void)
{
get_char_pos();
return 0;
}
8.第6章的程序清單6.20中,power()函數(shù)返回一個double類型數(shù)的正整數(shù) 次冪。改進(jìn)該函數(shù),使其能正確計算負(fù)冪。另外,函數(shù)要處理0的任何次冪 都為0,任何數(shù)的0次冪都為1(函數(shù)應(yīng)報告0的0次冪未定義,因此把該值處 理為1)。要使用一個循環(huán),并在程序中測試該函數(shù)。
#include <stdio.h>
double power(double n, int p)
{
int i;
double pow = 1.0;
if ((0 == p) && (0 == n))
{
printf("0 to the 0 undefined, using 1 as the value.\n");
return pow;
}
if (0 == n)
{
pow = 0.0;
return pow;
}
if (0 == p)
{
return pow;
}
if (p > 0)
{
for (i = 1; i <= p; i++)
{
pow *= n;
}
return pow;
}
else
{
for (i = 1; i <= -p; i++)
{
pow *= 1 / n;
}
return pow;
}
}
int main(void)
{
double x, xpow;
int exp;
printf("Enter a number and the integer power");
printf(" to which\nthe number will be raised. Enter q");
printf(" to quit.\n");
while (scanf("%lf%d", &x, &exp) == 2)
{
xpow = power(x, exp);
printf("%.3g to the power %d is %.5g.\n", x, exp, xpow);
printf("Enter next pair of numbers or q to quit.\n");
}
printf("Hope you enjoyed this power trip -- bye!\n");
return 0;
}
9.使用遞歸函數(shù)重寫編程練習(xí)8。
#include <stdio.h>
double power(double n, int p)
{
double pow = 1.0;
if ((0 == p) && (0 == n))
{
printf("0 to the 0 undefined, using 1 as the value.\n");
return pow;
}
if (0 == n)
{
pow = 0.0;
return pow;
}
if (0 == p)
{
return pow;
}
if (p > 0)
{
return n * power(n, p - 1);
}
else
{
return power(n, p + 1) / n;
}
}
int main(void)
{
double x, xpow;
int exp;
printf("Enter a number and the integer power");
printf(" to which\nthe number will be raised. Enter q");
printf(" to quit.\n");
while (scanf("%lf %d", &x, &exp) == 2)
{
xpow = power(x, exp);
printf("%.3g to the power %d is %.5g.\n", x, exp, xpow);
printf("Enter next pair of numbers or q to quit.\n");
}
printf("Hope you enjoyed this power trip -- bye!\n");
return 0;
}
10.為了讓程序清單9.8中的to_binary()函數(shù)更通用,編寫一個to_base_n() 函數(shù)接受兩個在2~10范圍內(nèi)的參數(shù),然后以第2個參數(shù)中指定的進(jìn)制打印第 1個參數(shù)的數(shù)值。例如,to_base_n(129, 8)顯示的結(jié)果為201,也就是129的 八進(jìn)制數(shù)。在一個完整的程序中測試該函數(shù)。
#include <stdio.h>
void to_base_n(int x, int base)
{
int r;
r = x % base;
if (x >= base)
{
to_base_n(x / base, base);
}
printf("%d", r);
return;
}
int main(void)
{
int b;
long int n;
printf("Please enter a number (q to quit): ");
while (scanf("%ld", &n) == 1)
{
if (n <= 0)
{
printf("Illegal data! Please enter again: ");
continue;
}
printf("Please enter a base system number (2 - 10): ");
while (scanf("%d", &b) != 1 || (b < 2 || b > 10))
{
while (getchar() != '\n')
continue;
printf("Please enteragain (2 - 10): ");
}
printf("%d in %d base system is: ", n, b);
to_base_n(n, b);
printf("\nYou can enter a number again (q to quit): ");
}
printf("Done.\n");
return 0;
}
11.編寫并測試Fibonacci()函數(shù),該函數(shù)用循環(huán)代替遞歸計算斐波那契 數(shù)。文章來源:http://www.zghlxwxcb.cn/news/detail-461833.html
#include <stdio.h>
void Fibonacci(int len)
{
int i;
unsigned long t, x, y;
x = y = 1;
for (i = 0; i < len; i++)
{
printf("%lu\n", x);
t = x + y;
x = y;
y = t;
}
return;
}
int main(void)
{
int n;
printf("Please enter a integer (<= 0 or q to quit): ");
while (scanf("%d", &n) == 1)
{
printf("Top %d items of Fibonacci sequence:\n", n);
Fibonacci(n);
printf("You can enter again (<= 0 or q to quit): ");
}
printf("Done.\n");
return 0;
}
文章來源地址http://www.zghlxwxcb.cn/news/detail-461833.html
到了這里,關(guān)于C Primer Plus第九章編程練習(xí)答案的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!