BESTCODER ROUND92 1001.Skip the Class

问题描述

终于又开学啦。呃喵最喜欢的就是开学了,因为这样她又可以愉快地翘课了(啊?)
呃喵接下来有n节课程需要上(换句话说,可以翘。)
每节课程有相应的课程类型与课程翘课价值。
有一点需要注意的是,呃喵不可以翘同一类课程超过两次,就是如果这类课已经翘了两次,接下来就一定要上。
问你在这个条件下,呃喵可以获得的最大翘课价值。

输入描述

第一行为一个整数T,代表数据组数。
接下来,对于每组数据——
第一行一个整数n,表示接下来需要依次上的课程数量,
接下来有n行,每行包括一个仅由’a’~’z’构成的长度不超过10的字符串s与一个正整数v。
其中字符串表示课程的类型,相同的字符串代表相同的课程。

数据保证——
1 <= T <= 1000
对于每组数据,1 <= n <= 100,1 <= |s| <= 10, 1 <= v <= 1000

输出描述

对于每组数据,输出一行。
该行有1个整数,表示呃喵可以获得的最大翘课价值。

输入样例

2
5
english 1
english 2
english 3
math 10
cook 100
2
a 1
a 2

输出样例

115
3

大概思路:

扫一遍,将有多少个科目记下来。
然后再扫一遍。记录每个科目出现的次数,并记录位置。
我现在只能想到这么做。据说可以用STL,但我现在不会···

代码:

#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;

typedef struct {
    char name[15];
    int number;
} Class;

int main()
{
    //freopen("in.txt","r",stdin);//一定要记得注释掉,因为这个WA了一发T_T
    int T;
    cin>>T;

    while(T--)
    {
        int n,ans=0,count=0;
        cin>>n;
        Class one[101];
        char cnt[101][11];//记录每个科目,和有多少个科目
        int m=0;

        for(int i=0;i<n;++i){
            cin>>one[i].name;
            cin>>one[i].number;
            if(i==0){
                count++;
                strcpy(cnt[m],one[i].name);
                m++;
                continue;
            }
            for(int j=0;j<m;++j){
                if(strcmp(one[i].name,cnt[j])==0)
                    break;
                if(j==m-1){
                    count++;
                    strcpy(cnt[m],one[i].name);//统计有多少科目
                    m++;
                }
            }
        }

        for(int i=0;i<count;++i){
            int num=0,adress[101]={0};

            for(int j=0;j<n;++j){
                if(strcmp(cnt[i],one[j].name)==0){//记录每个科目出现的地方
                    adress[num]=j;
                    num++;//每个科目出现了多少次
                }
            }

            if(num<3){
                for(int l=0;l<num;++l)
                    ans+=one[adress[l]].number;
            }else {
                int valuef=0;
                int values=0;
                for(int l=0;l<num;++l){
                    if(one[adress[l]].number>=values&&valuef<=one[adress[l]].number){
                        values=valuef;
                        valuef=one[adress[l]].number;
                    }else if(one[adress[l]].number>=values)
                        values=one[adress[l]].number;
                }//价值排序
                ans+=valuef+values;
            }

        }
        cout<<ans<<endl;
    }
    return 0;
}
基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究(Matlab代码实现)内容概要:本文围绕“基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究”,介绍了利用Matlab代码实现配电网可靠性的仿真分析方法。重点采用序贯蒙特卡洛模拟法对配电网进行长时间段的状态抽样与统计,通过模拟系统元件的故障与修复过程,评估配电网的关键可靠性指标,如系统停电频率、停电持续时间、负荷点可靠性等。该方法能够有效处理复杂网络结构与设备时序特性,提升评估精度,适用于含分布式电源、电动汽车等新型负荷接入的现代配电网。文中提供了完整的Matlab实现代码与案例分析,便于复现和扩展应用。; 适合人群:具备电力系统基础知识和Matlab编程能力的高校研究生、科研人员及电力行业技术人员,尤其适合从事配电网规划、运行与可靠性分析相关工作的人员; 使用场景及目标:①掌握序贯蒙特卡洛模拟法在电力系统可靠性评估中的基本原理与实现流程;②学习如何通过Matlab构建配电网仿真模型并进行状态转移模拟;③应用于含新能源接入的复杂配电网可靠性定量评估与优化设计; 阅读建议:建议结合文中提供的Matlab代码逐段调试运行,理解状态抽样、故障判断、修复逻辑及指标统计的具体实现方式,同时可扩展至不同网络结构或加入更多不确定性因素进行深化研究。
你遇到的错误: ``` Cannot find name 'round' ``` 是因为你在使用 `round(...)` 函数之前**没有定义它**,TypeScript 不知道 `round` 是什么。 --- ### ✅ 解决方法:**先定义 `round` 函数**,再使用它 你可以将 `round` 函数定义为一个 **工具函数**,放在代码顶部或单独的工具文件中。 --- ### ✅ 正确示例:定义 `round` 函数 ```ts // 定义 round 工具函数 function round(value: number, precision: number): number { const multiplier = Math.pow(10, precision); return Math.round((value + Number.EPSILON) * multiplier) / multiplier; } ``` --- ### ✅ 放置位置建议 确保 `round` 函数在你使用它之前就已经定义,比如: ```ts class YourServiceOrComponent { // ✅ 在类内部定义 private round(value: number, precision: number): number { const multiplier = Math.pow(10, precision); return Math.round((value + Number.EPSILON) * multiplier) / multiplier; } private aggregateAndCalculate(...) { // 使用 this.round(...) result.push({ TOTTIME: this.round(item.TOTTIME, 3), DWONTIME: this.round(item.DWONTIME, 3), // ... }); } } ``` --- ### ✅ 或者作为全局函数(不推荐在大型项目中) ```ts // utils.ts export function round(value: number, precision: number): number { const multiplier = Math.pow(10, precision); return Math.round((value + Number.EPSILON) * multiplier) / multiplier; } ``` 然后在组件中引入使用: ```ts import { round } from './utils'; result.push({ TOTTIME: round(item.TOTTIME, 3), DWONTIME: round(item.DWONTIME, 3), // ... }); ``` --- ### ✅ 总结 | 问题 | 原因 | 解决方法 | |------|------|-----------| | `Cannot find name 'round'` | 没有定义 `round` 函数 | 提前定义并确保作用域正确 | --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值