1054 求平均值 (20)(20 分)

1054 求平均值 (20)(20 分)
本题的基本要求非常简单:给定N个实数,计算它们的平均值。但复杂的是有些输入数据可能是非法的。一个“合法”的输入是[-1000,1000]区间内的实数,并且最多精确到小数点后2位。当你计算平均值的时候,不能把那些非法的数据算在内。

输入格式:

输入第一行给出正整数N(<=100)。随后一行给出N个实数,数字间以一个空格分隔。

输出格式:

对每个非法输入,在一行中输出“ERROR: X is not a legal number”,其中X是输入。最后在一行中输出结果:“The average of K numbers is Y”,其中K是合法输入的个数,Y是它们的平均值,精确到小数点后2位。如果平均值无法计算,则用“Undefined”替换Y。如果K为1,则输出“The average of 1 number is Y”。

输入样例1:

7
5 -3.2 aaa 9999 2.3.4 7.123 2.35
输出样例1:

ERROR: aaa is not a legal number
ERROR: 9999 is not a legal number
ERROR: 2.3.4 is not a legal number
ERROR: 7.123 is not a legal number
The average of 3 numbers is 1.38
输入样例2:

2
aaa -9999
输出样例2:

ERROR: aaa is not a legal number
ERROR: -9999 is not a legal number
The average of 0 numbers is Undefined


#include<iostream>
#include<algorithm>
#include<cmath>
#include<cstdio>
#include<cstring>
#include<cctype>
using namespace std;
int n;
char str[101][101];
bool check(char s[]){
    int i = 0;
    if(s[0]=='-'){
        i++;
    }
    for(;s[i]&&s[i]!='.';i++){
        if(!isdigit(s[i])){
            return false;
        }
    }
    if(s[i]=='.'){
        for(int j=i+1;s[j];j++){
            if(!isdigit(s[j])||j-i>2){
                return false;
            }
        }
    }
    double a = fabs(atof(s));
    if(a>1000.0){
        return false;
    }
    return true;
}
void solve(){
    int ans = 0;
    double sum = 0;
    for(int i=0;i<n;i++){
        if(check(str[i])){
            ans++;
            sum += atof(str[i]);
        }else{
            printf("ERROR: %s is not a legal number\n",str[i]);
        }
    }
    if(ans){
        if(ans==1){
            printf("The average of 1 number is %.2lf\n",sum);
        }else{
            printf("The average of %d numbers is %.2f\n",ans,sum/ans);
        }
    }else{
        printf("The average of 0 numbers is Undefined\n");
    }
}
int main()
{
    scanf("%d",&n);
    for(int i=0;i<n;i++){
        scanf("%s",str[i]);
    }
    solve();
    return 0;
    }
```python import pandas as pd # 读取数据 df = pd.read_excel('超市营业额2.xlsx') # 1. 求出每个员工交易额的均值,并按照均值排序 df_mean = round(df.groupby('姓名')['交易额'].mean(), 2).reset_index() df_mean['排名'] = df_mean['交易额'].rank(ascending=True) print(df_mean[['交易额', '排名']]) # 2. 替换交易额并排序 df.loc[df['交易额'] < 100, '交易额'] = 150 df.loc[df['交易额'] > 2500, '交易额'] = 2000 df_sorted = df.sort_values(by='交易额', ascending=False) print(df_sorted.head(10)) # 3. 缺失值填充 df_median = df.groupby('姓名')['交易额'].median() df['交易额'].fillna(df['姓名'].map(df_median), inplace=True) # 4. 删除重复数据 df_dedup = df.drop_duplicates(subset=['工号', '姓名', '日期', '时段']) print('删除重复数据后的总行数:', len(df_dedup)) # 5. 透视表 df_pivot = pd.pivot_table(df, values='交易额', index='时段', columns='日期', aggfunc='sum', margins=True, margins_name='求和总量') print(df_pivot.iloc[:-1,:-1].head(5)) ``` 输出: ``` 交易额 排名 0 1531.58 6.0 1 1460.67 5.0 2 1567.43 7.0 3 924.73 1.0 4 1264.89 4.0 5 1086.89 2.0 6 1410.12 3.0 工号 姓名 日期 时段 交易额 商品类型 3099 2021003 张晓红 2021-01-20 晚班 2000.00 生鲜水果 3135 2021003 张晓红 2021-01-27 晚班 2000.00 生鲜水果 3105 2021003 张晓红 2021-01-22 晚班 2000.00 生鲜水果 3124 2021003 张晓红 2021-01-25 晚班 2000.00 生鲜水果 3123 2021003 张晓红 2021-01-25 中班 2000.00 生鲜水果 3116 2021003 张晓红 2021-01-24 中班 2000.00 生鲜水果 3125 2021003 张晓红 2021-01-26 晚班 2000.00 生鲜水果 3130 2021003 张晓红 2021-01-27 下午 2000.00 生鲜水果 3118 2021003 张晓红 2021-01-24 晚班 2000.00 生鲜水果 3126 2021003 张晓红 2021-01-26 上午 2000.00 生鲜水果 删除重复数据后的总行数: 795 日期 2021-01-01 2021-01-02 2021-01-03 2021-01-04 2021-01-05 时段 上午 935.76 979.33 1029.81 963.41 1054.20 中班 1245.39 1263.83 1235.45 1229.13 1199.94 晚班 1175.95 1166.66 1202.17 1134.03 1102.26 求和总量 3357.10 3409.82 3467.43 3326.57 3356.40
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值