分子量~C语言

#include<stdio.h>
#include<string.h>
int main()
{
    int T;
    scanf("%d",&T);
    while(T--)
    {
    char s[20];
    int temp;
    double sum=0.0;
    scanf("%s",s);
    for(int i=0; i<strlen(s); i++)
    {
        switch(s[i])
        {
        case 'C':
        {
            if(s[i+1]>='0'&&s[i+1]<='9')                                   //用i+1去判断下一位是数字
            {
                temp=s[++i]-'0';
                while(s[i+1]>='0'&&s[i+1]<='9')                       //直到下一位不是数字为止,注意要++i;
                {
                   temp=temp*10+(s[++i]-'0');
                }
                sum=sum+12.01*temp;
            }
            else
                sum+=12.01;
        };
        break;
        case 'H':
        {
            if(s[i+1]>='0'&&s[i+1]<='9')
            {
                temp=s[++i]-'0';
                while(s[i+1]>='0'&&s[i+1]<='9')
                {
                   temp=temp*10+(s[++i]-'0');
                }
                sum=sum+temp*1.008;
            }
            else
                sum+=1.008;
        };
        break;
        case 'O':
        {
            if(s[i+1]>='0'&&s[i+1]<='9')          
            {
                temp=s[++i]-'0';
                while(s[i+1]>='0'&&s[i+1]<='9')    
                {
                   temp=temp*10+(s[++i]-'0');
                }
                sum=sum+temp*16.00;
            }
            else
                sum+=16.00;
        };
        break;
        case 'N':
        {
            if(s[i+1]>='0'&&s[i+1]<='9')
            {
                temp=s[++i]-'0';
                while(s[i+1]>='0'&&s[i+1]<='9')
                {
                   temp=temp*10+(s[++i]-'0');
                }
                sum=sum+temp*14.01;
            }
            else
                sum+=14.01;
        };
        break;
        }
    }
    printf("%.3lfg/mol\n",sum);
    }
    return 0;
}

C语言中计算大气不同高度的参数通常涉及到气象学中的物理模型,例如使用国际标准大气模型(ISA)或其他简化模型来估算温度、压力、密度等参数。这些参数随海拔高度的变化而变化,并且对于航空航天、天气预报等领域非常重要。 为了实现这个功能,你需要编写一些函数,利用数学公式来处理以下几个关键参数: 1. 温度(T):通常基于海平面的大气温度递减率,如 ISA 模型中的干绝热递减率。 ```c double isa_temperature(double height, double sea_level_temp) { // 使用ISA公式计算温度,这里仅提供基础结构,实际需要查找确切公式 const double gamma = 0.65; // 干绝热递减率 return sea_level_temp - (gamma * height); } ``` 2. 压力(P):可以依据理想气体定律和大气压强递减情况计算。 ```c double isa_pressure(double height, double sea_level_pressure) { const double g = 9.81; // 重力加速度 const double R = 287.05; // 平均气体常数 return sea_level_pressure / pow(1 + (g * height) / (R * isa_temperature(height, ...)), (R / g)); } ``` 3. 密度(rho):通过质量和体积的关系求得。 ```c double isa_density(double pressure, double temperature) { const double M = 0.0289644; // 平均分子量,空气 return pressure / (R * temperature) * M; } ``` 注意:这只是一个简化的示例,实际计算可能会更复杂,包括考虑湿度、风速等因素,而且这些公式可能需要根据具体的高度范围和大气条件进行修正。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值