c语言部分题集

7-66 求e的近似值

自然常数 e 可以用级数 1+1/1!+1/2!+⋯+1/n!+⋯ 来近似计算。本题要求对给定的非负整数 n,求该级数的前 n+1 项和。

输入格式:
输入第一行中给出非负整数 n(≤1000)。

输出格式:
在一行中输出部分和的值,保留小数点后八位。

输入样例:

10

输出样例:

2.71828180

代码:

#include<bits/stdc++.h>
using namespace std;
int main(){
    double z=1,sum=1,n,m;
    cin>>n;
    double k=1;
    for(int i=1;i<=n;i++){
        k=k*i;
        m=1/k;
        sum+=m;
    }
    printf("%.8lf",sum);
    return 0;
}

7-67 求分数序列前N项和

本题要求编写程序,计算序列 2/1+3/2+5/3+8/5+… 的前N项之和。注意该序列从第2项起,每一项的分子是前一项分子与分母的和,分母是前一项的分子。

输入格式:
输入在一行中给出一个正整数N。

输出格式:
在一行中输出部分和的值,精确到小数点后两位。题目保证计算结果不超过双精度范围。

输入样例:

20

输出样例:

32.66

代码:

#include<bits/stdc++.h>
using namespace std;
int main(){
    double s=0,n,z=2,m=1,k;
    cin>>n;
    for(int i=1;i<=n;i++){
        s+=z/m;//求和
        k=z;//记下前一项的分子
        z=z+m;//分子为前一项的分子分母之和
        m=k;//分母为前一项的分子
    }
    printf("%.2lf",s);
    return 0;
}

7-68 打印菱形图案

本题要求编写程序,打印一个高度为n的、由“*”组成的正菱形图案。

输入格式:
输入在一行中给出一个正的奇数n。

输出格式:
输出由n行星号“*”组成的菱形,如样例所示。每个星号后跟一个空格。

输入样例:

7

输出样例:

      * 
    * * * 
  * * * * * 
* * * * * * * 
  * * * * * 
    * * * 
      * 

代码:

#include<bits/stdc++.h>
using namespace std;
int main(){
    int n;
    cin>>n;
    for(int i=1;i<=n/2;i++){
        for(int j=0;j<n-2*i+1;j++)//控制空格
            cout<<' ';
        for(int k=0;k<2*i-1;k++)//控制*的数量
            cout<<"* ";
        cout<<endl;
    }//上半段
    for(int i=n/2+1;i>=1;i--){
        for(int j=0;j<n-2*i+1;j++)
            cout<<' ';
        for(int k=0;k<2*i-1;k++)
            cout<<"* ";
        cout<<endl;
    }//下半段
    return 0;
}

7-69 猴子吃桃问题

一只猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个;第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半加一个。到第N天早上想再吃时,见只剩下一个桃子了。问:第一天共摘了多少个桃子?

输入格式:
输入在一行中给出正整数N(1<N≤10)。

输出格式:
在一行中输出第一天共摘了多少个桃子。

输入样例:

3

输出样例:

10

代码:

#include<bits/stdc++.h>
using namespace std;
int main(){
    int a;
    cin>>a;
    int sum=1;
    for(int i=1;i<a;i++)
        sum=(sum+1)*2;
    cout<<sum;
    return 0;
}

7-73 谁先倒

划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就输了,输家罚一杯酒。两人同赢或两人同输则继续下一轮,直到唯一的赢家出现。

下面给出甲、乙两人的酒量(最多能喝多少杯不倒)和划拳记录,请你判断两个人谁先倒。

输入格式:
输入第一行先后给出甲、乙两人的酒量(不超过100的非负整数),以空格分隔。下一行给出一个正整数N(≤100),随后N行,每行给出一轮划拳的记录,格式为:

甲喊 甲划 乙喊 乙划

其中喊是喊出的数字,划是划出的数字,均为不超过100的正整数(两只手一起划)。

输出格式:
在第一行中输出先倒下的那个人:A代表甲,B代表乙。第二行中输出没倒的那个人喝了多少杯。题目保证有一个人倒下。注意程序处理到有人倒下就终止,后面的数据不必处理。

输入样例:

1 1
6
8 10 9 12
5 10 5 10
3 8 5 12
12 18 1 13
4 16 12 15
15 1 1 16

输出样例:

A
1

代码:

#include<bits/stdc++.h>
using namespace std;
int main(){
    int a,b,x1,x2,y1,y2;
    int n;
    cin>>a>>b;
    int c=0,d=0;
    cin>>n;
    for(int i=0;i<n;i++){
        cin>>x1>>x2>>y1>>y2;
        if(x2==(x1+y1)&&y2!=(x1+y1))
            c++;
        if(y2==(x1+y1)&&x2!=(x1+y1))
            d++;
        if(a<c){
            printf("A\n%d",d);
            break;
        }
        else if(b<d){
            printf("B\n%d",c);
            break;
        }
        
    }
    return 0;
}

7-75 到底是不是太胖了

据说一个人的标准体重应该是其身高(单位:厘米)减去100、再乘以0.9所得到的公斤数。真实体重与标准体重误差在10%以内都是完美身材(即 | 真实体重 − 标准体重 | < 标准体重×10%)。已知市斤是公斤的两倍。现给定一群人的身高和实际体重,请你告诉他们是否太胖或太瘦了。

输入格式:
输入第一行给出一个正整数N(≤ 20)。随后N行,每行给出两个整数,分别是一个人的身高H(120 < H < 200;单位:厘米)和真实体重W(50 < W ≤ 300;单位:市斤),其间以空格分隔。

输出格式:
为每个人输出一行结论:如果是完美身材,输出You are wan mei!;如果太胖了,输出You are tai pang le!;否则输出You are tai shou le!。

输入样例:

3
169 136
150 81
178 155

输出样例:

You are wan mei!
You are tai shou le!
You are tai pang le!

代码:

#include<bits/stdc++.h>
using namespace std;
int main(){
    int n,x,y;
    cin>>n;
    int b;
    for(int i=0;i<n;i++){
        cin>>x>>y;
        b=(x-100)*0.9*2;
        if(abs(y-b)<b*0.1)
            printf("You are wan mei!\n");
        else if(y>b)
            printf("You are tai pang le!\n");
        else if(y<b)
            printf("You are tai shou le!\n");
    }
    return 0;
}

7-76 情人节

以上是朋友圈中一奇葩贴:“2月14情人节了,我决定造福大家。第2个赞和第14个赞的,我介绍你俩认识…………咱三吃饭…你俩请…”。现给出此贴下点赞的朋友名单,请你找出那两位要请客的倒霉蛋。

输入格式:
输入按照点赞的先后顺序给出不知道多少个点赞的人名,每个人名占一行,为不超过10个英文字母的非空单词,以回车结束。一个英文句点.标志输入的结束,这个符号不算在点赞名单里。

输出格式:
根据点赞情况在一行中输出结论:若存在第2个人A和第14个人B,则输出“A and B are inviting you to dinner…”;若只有A没有B,则输出“A is the only one for you…”;若连A都没有,则输出“Momo… No one is for you …”。

输入样例1:

GaoXZh
Magi
Einst
Quark
LaoLao
FatMouse
ZhaShen
fantacy
latesum
SenSen
QuanQuan
whatever
whenever
Potaty
hahaha
.

输出样例1:

Magi and Potaty are inviting you to dinner...

输入样例2:

LaoLao
FatMouse
whoever
.

输出样例2:

FatMouse is the only one for you...

输入样例3:

LaoLao
.

输出样例3:

Momo... No one is for you ..

代码:

#include<bits/stdc++.h>
using namespace std;
int main(){
    string s[9999];
    int k=0,i=1;
    while(cin>>s[i]){
        if(s[i]==".")
            break;
        k++;
        i++;
    }
    if(k<=1)
        cout<<"Momo... No one is for you ...";
    else if(k>=2&&k<14)
        cout<<s[2]<<" is the only one for you...";
    else if(k>=14)
        cout<<s[2]<<" and "<<s[14]<<" are inviting you to dinner...";
    return 0;
}

7-80 交换最小值和最大值

本题要求编写程序,先将输入的一系列整数中的最小值与第一个数交换,然后将最大值与最后一个数交换,最后输出交换后的序列。

注意:题目保证最大和最小值都是唯一的。

输入格式:
输入在第一行中给出一个正整数N(≤10),第二行给出N个整数,数字间以空格分隔。

输出格式:
在一行中顺序输出交换后的序列,每个整数后跟一个空格。

输入样例:

5
8 2 5 1 4

输出样例:

1 2 5 4 8 

代码:

#include<bits/stdc++.h>
using namespace std;
int a[10],mi=1,ma=1,k,n;
int main(){
    cin>>n;
    for(int i=0;i<n;i++){
        cin>>a[i];
        if(a[i]<a[mi])
            mi=i;
    }
    swap(a[0],a[mi]);
    for(int i=0;i<n;i++)
        if(a[i]>a[ma])
            ma=i;
    swap(a[n-1],a[ma]);
    for(int i=0;i<n;i++)
        cout<<a[i]<<' ';
    return 0;
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值