浙大版《C语言程序设计实验与习题指导(第4版)》题目集(4)

导读:本篇文章讲解 浙大版《C语言程序设计实验与习题指导(第4版)》题目集(4),希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

浙大版《C语言程序设计实验与习题指导(第4版)》题目集

实验2-4-6 求交错序列前N项和

本题要求编写程序,计算交错序列 1-2/3+3/5-4/7+5/9-6/11+… 的前N项之和。
输入格式:输入在一行中给出一个正整数N。
输出格式:在一行中输出部分和的值,结果保留三位小数。
输入样例:
5
输出样例:
0.917

#include <stdio.h>
#include <math.h>

int main(){
    int N;
    double i;
    double sum = 0;
    double n;
    float a = 1;
    scanf("%d",&N);
    for(i=1;i<=N;i=i+1){
        n = i / a * pow(-1,i+1);
        sum = sum + n;
        a = a + 2;
    }
    printf("%.3f\n",sum);

    return 0;
}

实验2-4-7 求平方与倒数序列的部分和

本题要求对两个正整数m和n(m≤n)编写程序,计算序列和m2+1/m+(m+1)2+1/(m+1)+⋯+n2+1/n。
输入格式:
输入在一行中给出两个正整数m和n(m≤n),其间以空格分开。
输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后六位。题目保证计算结果不超过双精度范围。
输入样例:
5 10
输出样例:
sum = 355.845635

#include <stdio.h>

int main(){
    int m;
    int n;
    double i;
    double sum1 = 0;
    double sum2 = 0;
    scanf("%d %d",&m,&n);
    for(i=m;i<=n;i++){
        sum1 = sum1 + 1 / i;
    }
    for(i=m;i<=n;i++){
        sum2 = sum2 + i * i;
    }
    sum1 = sum1 + sum2;
    printf("sum = %f\n",sum1);
    
    return 0;
}

实验2-4-8 找出三位水仙花数

本题要求编写程序,输出给定正整数M和N区间内的所有三位水仙花数。三位水仙花数,即其个位、十位、百位数字的立方和等于该数本身。
输入格式:
输入在一行中给出两个正整数M和N(100≤M≤N≤999)。
输出格式:
顺序输出M和N区间内所有三位水仙花数,每一行输出一个数。若该区间内没有三位水仙花数,则无输出。
如果M或者N不符合题目的要求,则输出Invalid Value.。
输入样例1:
100 400
输出样例1:
153
370
371
输入样例2:
500 600
输出样例2:

输入样例3:
990 101
输出样例3:
Invalid Value.

#include <stdio.h>
#include <math.h>

int main()
{
    int M;
    int N;
    int ge;
    int shi;
    int bai;
    int sum;
    int i;
    scanf("%d %d",&M,&N);
    if(M <= N && M >= 100 && M <= 999 && N >= 100 && N <= 999){
        for(i=M;i<=N;i++){
            ge = i % 10;
            shi = i / 10 % 10;
            bai = i / 100;
            sum = pow(ge,3) + pow(shi,3) + pow(bai,3);
            if(i == sum){
                printf("%d\n",i);
            }
        }
    }else{
        printf("Invalid Value.\n");
    }

    return 0;
}

实验2-5-2 生成3的乘方表

输入一个非负整数n,生成一张3的乘方表,输出30~3n的值。可调用幂函数计算3的乘方。
输入格式:
输入在一行中给出一个非负整数n。
输出格式:
按照幂的递增顺序输出n+1行,每行格式为“pow(3,i) = 3的i次幂的值”。题目保证输出数据不超过长整型整数的范围。
输入样例:
3
输出样例:
pow(3,0) = 1
pow(3,1) = 3
pow(3,2) = 9
pow(3,3) = 27

#include <stdio.h>
#include <math.h>

int main(){
    int n;
    int i;
    int sum;
    scanf("%d",&n);
    for(i=0;i<=n;i++){
        sum = pow(3,i);
        printf("pow(3,%d) = %d\n",i,sum);
    }
    return 0;
}

实验2-5-3 求平方根序列前N项和

本题要求编写程序,计算平方根序列根号1​+根号2+根号3+⋯的前N项之和。可包含头文件math.h,并调用sqrt函数求平方根。
输入格式:
输入在一行中给出一个正整数N。
输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后两位。题目保证计算结果不超过双精度范围。
输入样例:
10
输出样例:
sum = 22.47

#include <stdio.h>
#include <math.h>

int main()
{
    int N;
    double i;
    double sum = 0;
    scanf("%d",&N);
    for(i=1;i<=N;i++){
        sum = sum + sqrt(i);
    }
    printf("sum = %.2f\n",sum);

    return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/120202.html

(0)
seven_的头像seven_bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!