首页 > 其他分享 >CSP第31次认证题解 2023.9

CSP第31次认证题解 2023.9

时间:2023-12-02 15:24:43浏览次数:43  
标签:tmp opt return int 题解 31 2023.9 now id

A、坐标变换(其一)

样例输入

3 2
10 10
0 0
10 -20
1 -1
0 0

样例输出

21 -11
20 -10

题解

按照题目,一个循环即可

#include <bits/stdc++.h>
using namespace std;
#define N 200010
#define ll long long

template <class T>
inline void read(T& a){
    T x = 0, s = 1;
    char c = getchar(); 
    while(!isdigit(c)){ if(c == '-')  s = -1; c = getchar(); }
    while(isdigit(c)){ x = x * 10 + (c ^ '0'); c = getchar(); }
    a = x * s;
    return ; 
}

int n, m; 
int dx[N], dy[N]; 

int main(){
    cin >> m >> n;
    for(int i = 1; i <= m; i++)
        read(dx[i]), read(dy[i]); 
    for(int i = 1; i <= n; i++){
        int x, y; 
        cin >> x >> y; 
        for(int j = 1; j <= m; j++){
            x += dx[j]; 
            y += dy[j]; 
        }
        cout << x << " " << y << endl; 
    } 
    return 0; 
}

B、坐标变换(其二)

样例输入

10 5
2 0.59
2 4.956
1 0.997
1 1.364
1 1.242
1 0.82
2 2.824
1 0.716
2 0.178
2 4.094
1 6 -953188 -946637
1 9 969538 848081
4 7 -114758 522223
1 9 -535079 601597
8 8 159430 -511187

样例输出

-1858706.758 -83259.993
-1261428.46 201113.678
-75099.123 -738950.159
-119179.897 -789457.532
114151.88 -366009.892

题解

注意到这两个操作分别可互相叠加。对操作一作前缀积,操作二作前缀和。

#include <bits/stdc++.h>
using namespace std;
#define N 200010
#define ll long long

template <class T>
inline void read(T& a){
    T x = 0, s = 1;
    char c = getchar(); 
    while(!isdigit(c)){ if(c == '-')  s = -1; c = getchar(); }
    while(isdigit(c)){ x = x * 10 + (c ^ '0'); c = getchar(); }
    a = x * s;
    return ; 
}

int n, m; 
double opt1[N]; 
double opt2[N]; 

double sum1[N], sum2[N]; 

int main(){
    cin >> m >> n;
    for(int i = 1; i <= m; i++){
        int opt; cin >> opt; 
        if(opt == 1) cin >> opt1[i]; 
        else{
            cin >> opt2[i]; 
            opt1[i] = 1; 
        } 
    }
    sum1[0] = 1;
    for(int i = 1; i <= m; i++){
        sum1[i] = sum1[i-1] * opt1[i]; 
        sum2[i] = sum2[i-1] + opt2[i]; 
    }
     
    for(int i = 1; i <= n; i++){
        int l, r; 
        double x, y; 
        cin >> l >> r; 
        cin >> x >> y; 
        double k1 = 0, k2 = 0; 
        k1 = sum1[r] / sum1[l-1]; 
        k2 = sum2[r] - sum2[l-1]; 
        double tmp = x; 
        x = x * cos(k2) - y * sin(k2); 
        y = tmp * sin(k2) + y * cos(k2);
        x *= k1; y *= k1; 
        printf("%.3lf %.3lf\n", x, y);  
    }
    return 0; 
}

C、梯度求解


样例 1

输入:

2 2
x1 x1 x1 * x2 + *
1 2 3
2 3 4

输出:

15
3

样例 2

输入:

3 5
x2 x2 * x2 * 0 + -100000 -100000 * x2 * -
3 100000 100000 100000
2 0 0 0
2 0 -1 0
2 0 1 0
2 0 100000 0

输出:

0
70
73
73
999999867

题解

对表达式建立树,每个节点对其值进行分类。在求导的时候,难点在于乘法,可以发现无论是什么乘法,其实都使用最后一个公式是通用的。
为了方便,我们在求导时,直接在原树的基础上向后增加节点。如果是加法,那么其左右儿子就是原树左右儿子求导后的形态。如果是减法,同理(一定要注意左右顺序!!是谁减谁!!
在做乘法求导时,直接套用最后那个公式,将当前节点新建成加分节点,左右儿子分别新建为乘法节点。对于左儿子,其左儿子为原树的左儿子求导的结果,右儿子直接接到原树上的右儿子即可,跟线段树合并的做法相同。新建节点的右儿子同理,左儿子直接接到原树的左儿子,右儿子接求导结果返回的新建节点。

建立好新树之后,直接便利一遍带入值即可。(注意负值取模!)

#include <bits/stdc++.h>
using namespace std;
#define N 200010
#define ll long long
#define int long long

template <class T>
inline void read(T& a){
    T x = 0, s = 1;
    char c = getchar(); 
    while(!isdigit(c)){ if(c == '-')  s = -1; c = getchar(); }
    while(isdigit(c)){ x = x * 10 + (c ^ '0'); c = getchar(); }
    a = x * s;
    return ; 
}

int n, m; 
struct node{
    int isopt, opt; // 1: + 2: - 3: * 
    int isnum, val; // 数字
    int isx, id; // 变量

    int lc, rc; 
} t[N], pp[N]; 
stack <int> stac; 

const int mod = 1e9 + 7; 

int did; 
int variable[N]; // 变量的值

#define lson t[u].lc
#define rson t[u].rc

int id = n; 
int dfs(int now, int k){  // 返回以当前节点为根的求导后的新节点的编号
    if(t[now].isopt == 1){
        id++; 
        t[id].isopt = 1; 
        t[id].opt = t[now].opt; 
        int u = id; 
        if(t[u].opt == 1 || t[u].opt == 2){
            t[u].lc = dfs(t[now].lc, k); 
            t[u].rc = dfs(t[now].rc, k); 
        }
        else{
            t[u].opt = 1; 
            t[u].lc = ++id;
            t[lson].isopt = 1;
            t[lson].opt = 3;
            t[lson].lc = dfs(t[now].lc, k); 
            t[lson].rc = t[now].rc;

            t[u].rc = ++id;
            t[rson].isopt = 1;
            t[rson].opt = 3;
            t[rson].lc = t[now].lc;
            t[rson].rc = dfs(t[now].rc, k); 
        }
        return u; 
    }
    else if(t[now].isnum == 1){
        id++; 
        t[id].isnum = 1; 
        t[id].val = 0; 
        return id; 
    }
    else{
        id++;   
        t[id].isnum = 1; 
        if(t[now].id == k){
            t[id].val = 1; 
        }
        else{
            t[id].val = 0; 
        }
        return id; 
    }
    return 0; 
}

int dfs2(int now){
    if(t[now].isopt == 1){
        if(t[now].opt == 1) {
            int tmp = (dfs2(t[now].lc) + dfs2(t[now].rc)) % mod; 
            while(tmp < 0)
                tmp += mod;
            return tmp; 
        }
        if(t[now].opt == 2) {
            int tmp = (dfs2(t[now].rc) - dfs2(t[now].lc)) % mod; 
            while(tmp < 0)
                tmp += mod;
            return tmp; 
        }
        if(t[now].opt == 3) {
            int tmp = dfs2(t[now].lc) * dfs2(t[now].rc); 
            while(tmp < 0)
                tmp += mod; 
            return tmp % mod; 
        }
    }
    else if(t[now].isnum == 1){
        return t[now].val; 
    }
    else{
        return variable[t[now].id] % mod; 
    }
    return 0; 
}

signed main(){
    cin >> n >> m; 
    char ch = getchar(); 
    string tmp; 
    getline(cin, tmp);  
    int p = 0; 
    int i = 0; 
    
    while(p < tmp.length()){
        string s;
        int q = p; 
        while(tmp[q] != ' ' && q < tmp.length()){
            s.push_back(tmp[q]); 
            q++; 
        }
        p = q + 1; 
        i++; 
        if(s[0] == '+' || (s[0] == '-' && s.length() == 1) || s[0] == '*'){
            t[i].isopt = 1; 
            if(s[0] == '+') t[i].opt = 1; 
            if(s[0] == '-') t[i].opt = 2; 
            if(s[0] == '*') t[i].opt = 3; 
            t[i].lc = stac.top(); stac.pop(); 
            t[i].rc = stac.top(); stac.pop(); 
            stac.push(i); 
        }
        else if(isdigit(s[0])){
            t[i].isnum = 1; 
            int x = 0; 
            for(int i = 0; i < s.length(); i++)
                x = x * 10 + (s[i] - '0'); 
            t[i].val = x; 
            stac.push(i); 
        }
        else if(s[0] == '-'){
        	int x = 0; 
        	t[i].isnum = 1; 
        	for(int i = 1; i < s.length(); i++)
        		x = x * 10 + (s[i] - '0'); 
        	t[i].val = x * (-1);
            stac.push(i); 
		}
        else{
            t[i].isx = 1; 
            int num = 0; 
            for(int i = 1; i < s.length(); i++)
                num = num * 10 + (s[i] - '0'); 
            t[i].id = num;
            stac.push(i);  
        }
        pp[i] = t[i]; // 存档
    }
    p = i; 
    for(int i = 1; i <= m; i++){
        cin >> did; 
        for(int j = 1; j <= n; j++)
            cin >> variable[j], t[i] = pp[i];
        id = p; 
        dfs(p, did); 
        cout << dfs2(p + 1) % mod << endl;
    }
    return 0; 

}

标签:tmp,opt,return,int,题解,31,2023.9,now,id
From: https://www.cnblogs.com/wondering-world/p/17871632.html

相关文章

  • 2023-2024-1 20231323《计算机基础与程序设计》第十周学习总结
    2023-2024-120231323《计算机基础与程序设计》第十周学习总结作业信息所属课程2023-2024-1-计算机基础与程序设计作业要求2023-2024-1计算机基础与程序设计第周作业作业目标自学教材《计算机科学概论》第12,13,14章《C语言程序设计》第9章并完成云班课测试作业......
  • Wi-Fi 7大普及来了!TP-LINK连上三款:319元起
    近日随着国内Wi-Fi7认证的推进,小米、华为、新华三等都纷纷上线了Wi-Fi7路由器,已发布的产品也计划推送OTA解锁。不过,之前的不少Wi-Fi7路由器都比较贵,普遍都在500元以上,老牌厂商TP-LINK开始出手打价格了。TP-LINK最新上架了三款Wi-Fi7路由器,分别是BE3600、BE5100和BE6500,三款配置......
  • 2023-2024-1 20231420 《计算机基础与程序设计》第十周学习总结
    2023-2024-120231420《计算机基础与程序设计》第十周学习总结1.作业信息这个作业属于哪个课程2023-2024-1《计算机基础与程序设计》这个作业要求在哪里2023-2024-1计算机基础与程序设计第十周作业这个作业的目标1.学习《计算机科学概论》第12,13,14章并完成云班课......
  • 使用Navicat For MSSQL连接绿色版SQLServer2008R2问题解决
    问题1、创建连接时出现错误:[IM002][Microsoft][ODBC驱动程序管理器]未发现数据源名称并且未指定默认驱动程序(0)Navicat来连接SQLserver,这里确实有点麻烦,出现错误[IM002][Microsoft][ODBC驱动程序管理器]未发现数据源名称并且未指定默认驱动程序(0),解决方法:进入Navicat的安装......
  • 2023-2024-1 20231419 《计算机基础与程序设计》第十周学习总结
    2023-2024-120231419《计算机基础与程序设计》第十周学习总结作业信息这个作业属于哪个课程https://edu.cnblogs.com/campus/besti/2023-2024-1-CFAP这个作业要求在哪里https://www.cnblogs.com/rocedu/p/9577842.html#WEEK10这个作业的目标自学《计算机科学概......
  • CF1368题解
    CF1368CodeforcesGlobalRound8ABC略。CF1368DlinkCF1368D题意给定\(n\)个非负整数\(a_1,\cdots,a_n\)。你可以进行如下操作:选择两个不同的下标\(i,j\)满足\(1\leqi,j\leqn\),并将\(a_i\getsa_i\\mathsf{AND}\a_j,\a_j\getsa_i\\mathsf{OR}\a_j\),两个赋值......
  • 2023-2024-1 20232311 《网络空间安全导论》 第四周学习
    教材学习内容总结第四章思维导图教材学习中的问题和解决过程问题1:网络空间生态系统的未来变化趋势有哪些?我国做出哪些应对?问题1解决方案:询问Chatgpt:人工智能和自动化技术会进一步发展,对网络空间的影响将进一步扩大和加深。例如,人工智能对于网络安全和隐私保护的作用将变......
  • newstarctf2023 reverse 题解汇总
    newstarctf2023reverse题解汇总week1easy_REdie查无壳64直接IDA启动跟到main函数找到两部分flag拼起来就行了。flag{we1c0me_to_rev3rse!!}ELFdie查64ELFIDA启动稍微读一下写个py逆一下它的加密就行了flag{D0_4ou_7now_wha7_ELF_1s?}importbase64a="VlxRV......
  • ISCTFpwn的ezpie题解
    目前接触的随机好像都与地址有关,而且还有一个特性也就是只是基址随机,只要有任意一个地址就可以知道其他所有具体地址。(libc和pie保护)这里将通过ezpie这道题介绍绕过pie的一种方式,泄露地址一获取全部地址的方法。本人还不太懂partiallywrite的原理,就不误人子弟了。这里我们看到v5......
  • 20231201
    新的一月。只能说这么练一周真的很累。今天下午和晚上效率极低。算了,当作放松罢。只能说这一周数据结构算是练上来一点了。希望明天的TrashRound不会挂。晚安。想起来了,今天早上又被班主任劝了一通「现在回来上whk还来得及。」欸,我不知道这是我第几次面对这个问题......