【牛客】几何糕手、国际裁判带师、数位dp?、灵异背包、矩阵快速幂签到、第一次放学

本文主要是介绍【牛客】几何糕手、国际裁判带师、数位dp?、灵异背包、矩阵快速幂签到、第一次放学,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 《几何糕手》
    • 题目描述
    • 思路
    • 代码
  • 《国际裁判带师》
    • 题目描述
    • 思路
    • 代码
  • 《数位dp?》
    • 题目描述
    • 思路
    • 代码
  • 《灵异背包》
    • 题目描述
    • 思路
    • 代码
  • 《矩阵快速幂签到》
    • 题目描述
    • 思路
    • 代码
  • 《第一次放学》
    • 题目描述
    • 思路
    • 代码

《几何糕手》

题目链接

题目描述

“芝士肾么?”

地上有一根木桩,在木桩上栓有一根长度为 a 的木绳,木绳的末端还栓有一根长度为 b 的木棍,现在小沙想要知道,木棍可能扫过的位置在地面上的投影面积有多大。

输入描述
第一行输入两个正整数 a,b,代表木绳以及木棍的长度。
保证有1≤a,b≤100。

输出描述
输出一个数字代表答案,答案保留10位小数。

示例1:
输入:

1 1

输出:

12.5663706144

思路

把木棍和绳子的长度加起来作为圆的半径,然后直接求圆的面积即可,这里想要使用圆周率Π的话可以使用acos(-1)来表示

代码

#include<bits/stdc++.h>
using namespace std;int main()
{double a,b;cin>>a>>b;printf("%.10lf",acos(-1)*pow(a+b,2));return 0;
}

《国际裁判带师》

题目链接

题目描述

“蒸馍?你不福气?”

在很多比赛中,会有如下图所示的计分表,每次得分之后会翻动来表示得分。
在这里插入图片描述
先给定如上图所示记分表,并给定一个长度为n 的比赛获胜记录,小沙需要记录整场比赛中,每次计分表变化之后,数字 0 出现了多少次。
小沙:“ACMer,帮帮我”。

输出描述
链接:
第一行,输入一个长度不超过 n 的字符串,保证字符串中仅包含 ab
其中 a 代表红方获胜得一分,b 代表蓝方获胜得一分。
保证有1≤n≤99。

示例1:
输入:

aab

输出:

8

说明:

第一次红方得分,计分表变成 0001,出现了3 个 0。 第二次红方得分,计分表变成 0002,出现了3 个 0。
第一次蓝方得分,计分表变成 0102,出现了 2 个 0。 总计出现了 8 次数字 0。

思路

遍历题目给出的字符串,记录每一个环节a和b对应的分数然后对每一个和环节a和b的分数计算有多少个0。

代码

#include<bits/stdc++.h>
using namespace std;int solve(int n)
{int ans=0;while(n>0){if(n%10==0)ans++;}return ans;
}int main()
{string s;cin>>s;int a=0,b=0;int ans=0;for(int i=0;i<s.size();++i){if(s[i]=='a')a++;else b++;if(a/10==0)ans++;if(a%10==0)ans++;if(b/10==0)ans++;if(b%10==0)ans++;}cout<<ans;return 0;
}

《数位dp?》

[题目链接](https://ac.n
owcoder.com/acm/contest/66877/A)

题目描述

给定一个数字n,你可以对它进行接下来的操作——

  • 选择数字中任意一个数位删除

例如对1024选择操作百位,数字则变成了124;对1024选择操作千位,数字则变成了024

我们称一个数字是干净的,当且仅当数字满足以下任意一种情况:

  • 这个数字是偶数且不含前导零
  • 这个数字为空

请问最少需要进行多少次操作,使得数字n变成干净

输入描述
第一行包含一个整数 n (1≤n≤109),表示这个数字的大小
输入的数字保证不含前导零

输出描述
输出最少需要的操作次数。
注意,因为一定能使得数字删成空,所以当前数字一定能变成干净的

示例1:
输入:

1024

输出:

0

说明:

当前数字无需操作便满足条件

示例2:
输入:

3

输出:

1

说明:

最少只需要删除一次即可把数字删成空
‘3’⇒’’

示例3:
输入:

233

输出:

2

说明:

最少只需要删除两次即可把数字删成偶数
233⇒23⇒2

思路

简单模拟,把这个数从后面往前面一直删除一直到遇到偶数就停止

代码

#include<bits/stdc++.h>
using namespace std;int main()
{int n;cin>>n;int ans=0;while(n){if(n%2==0)break;n/=10;ans++;}cout<<ans;return 0;
}

《灵异背包》

题目链接

题目描述

有n个正整数,现在,你可以选择将其中一些数放进灵异背包中,使得背包里面所有数的总和为偶数且最大,求能得到的最大值是多少?

注意:如果你不将任何数放进灵异背包,此时背包总和为0

输出描述
第一行包含一个正整数n (1≤n≤105 ),表示数字的数量
接下来n行包含n个正整数 a1 ,a2…,an (1≤ai ≤2×104),表示数字的大小

示例1:
输入:

3
2
5
6

输出:

8

说明:
当灵异背包里面有(2,5,6),此时总和为2+5+6=13,为奇数,不满足条件
当灵异背包里面有(2,6),此时总和为2+6=8,为偶数,且为最大值

示例2:
输入:

1
3

输出:

0

说明:

选择的灵异背包为空,总和为0

思路

偶数全部都可以加进来,奇数需要分类讨论,如果奇数个数是偶数个也可以全部加入,如果是奇数个就去掉最小的奇数

代码

#include<bits/stdc++.h>
using namespace std;int main()
{int n;bool pd=0;long long minzhi=INT_MAX;long long ans=0;cin>>n;long long input;while(n--){cin>>input;ans+=input;if(input&1){pd^=1;minzhi=min(minzhi,input);}}if(pd)ans-=minzhi;cout<<ans;return 0;
}

《矩阵快速幂签到》

题目链接

题目描述

在这里插入图片描述

输入描述
一个正整数 (1≤n≤998244351)

输出描述
一个整数,对应答案。

示例1:
输入:

1

输出:

2

示例2:
输入:

2

输出:

3

思路

这道题就是诈骗题,无脑输出一下最前面的那几项找找规律就会发现直接输出n+1就可以了

代码

#include<bits/stdc++.h>
using namespace std;int main()
{int n;cin>>n;cout<<(n+1)%998244353;return 0;
}

《第一次放学》

题目链接

题目描述

在这里插入图片描述

输入描述
在这里插入图片描述
输出描述
一个整数,表示目前学校里最多有多少同学是属于同一个班级的。

示例1:
输入:

6 3 3
3 1 2 3 3 2

输出:

3

思路

题目询问最多多少个同学是同一个班级,那我们直接找最大的那个班级进行对比,如果那个班级的人数更多那么剩下的n-k个人都是这个班级的,否则就是这个班级的人加上其他的班级的人,此时输出人数最大的班级的人数

代码

#include<bits/stdc++.h>
using namespace std;int main()
{int n,m,k;int a[(int)1e5+10];cin>>n>>m>>k;int input;int maxzhi=0;for(int i=0;i<n;++i){cin>>input;a[--input]++;maxzhi=max(maxzhi,a[input]);}if(maxzhi>n-k)cout<<n-k;else cout<<maxzhi;return 0;
}

这篇关于【牛客】几何糕手、国际裁判带师、数位dp?、灵异背包、矩阵快速幂签到、第一次放学的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/638264

相关文章

Rust中的Option枚举快速入门教程

《Rust中的Option枚举快速入门教程》Rust中的Option枚举用于表示可能不存在的值,提供了多种方法来处理这些值,避免了空指针异常,文章介绍了Option的定义、常见方法、使用场景以及注意事... 目录引言Option介绍Option的常见方法Option使用场景场景一:函数返回可能不存在的值场景

poj2576(二维背包)

题意:n个人分成两组,两组人数只差小于1 , 并且体重只差最小 对于人数要求恰好装满,对于体重要求尽量多,一开始没做出来,看了下解题,按照自己的感觉写,然后a了 状态转移方程:dp[i][j] = max(dp[i][j],dp[i-1][j-c[k]]+c[k]);其中i表示人数,j表示背包容量,k表示输入的体重的 代码如下: #include<iostream>#include<

hdu2159(二维背包)

这是我的第一道二维背包题,没想到自己一下子就A了,但是代码写的比较乱,下面的代码是我有重新修改的 状态转移:dp[i][j] = max(dp[i][j], dp[i-1][j-c[z]]+v[z]); 其中dp[i][j]表示,打了i个怪物,消耗j的耐力值,所得到的最大经验值 代码如下: #include<iostream>#include<algorithm>#include<

csu(背包的变形题)

题目链接 这是一道背包的变形题目。好题呀 题意:给n个怪物,m个人,每个人的魔法消耗和魔法伤害不同,求打死所有怪物所需的魔法 #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>//#include<u>#include<map

hdu4826(三维DP)

这是一个百度之星的资格赛第四题 题目链接:http://acm.hdu.edu.cn/contests/contest_showproblem.php?pid=1004&cid=500 题意:从左上角的点到右上角的点,每个点只能走一遍,走的方向有三个:向上,向下,向右,求最大值。 咋一看像搜索题,先暴搜,TLE,然后剪枝,还是TLE.然后我就改方法,用DP来做,这题和普通dp相比,多个个向上

电脑桌面文件删除了怎么找回来?别急,快速恢复攻略在此

在日常使用电脑的过程中,我们经常会遇到这样的情况:一不小心,桌面上的某个重要文件被删除了。这时,大多数人可能会感到惊慌失措,不知所措。 其实,不必过于担心,因为有很多方法可以帮助我们找回被删除的桌面文件。下面,就让我们一起来了解一下这些恢复桌面文件的方法吧。 一、使用撤销操作 如果我们刚刚删除了桌面上的文件,并且还没有进行其他操作,那么可以尝试使用撤销操作来恢复文件。在键盘上同时按下“C

hdu1011(背包树形DP)

没有完全理解这题, m个人,攻打一个map,map的入口是1,在攻打某个结点之前要先攻打其他一个结点 dp[i][j]表示m个人攻打以第i个结点为根节点的子树得到的最优解 状态转移dp[i][ j ] = max(dp[i][j], dp[i][k]+dp[t][j-k]),其中t是i结点的子节点 代码如下: #include<iostream>#include<algorithm

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

hdu4865(概率DP)

题意:已知前一天和今天的天气概率,某天的天气概率和叶子的潮湿程度的概率,n天叶子的湿度,求n天最有可能的天气情况。 思路:概率DP,dp[i][j]表示第i天天气为j的概率,状态转移如下:dp[i][j] = max(dp[i][j, dp[i-1][k]*table2[k][j]*table1[j][col] )  代码如下: #include <stdio.h>#include

usaco 1.1 Broken Necklace(DP)

直接上代码 接触的第一道dp ps.大概的思路就是 先从左往右用一个数组在每个点记下蓝或黑的个数 再从右到左算一遍 最后取出最大的即可 核心语句在于: 如果 str[i] = 'r'  ,   rl[i]=rl[i-1]+1, bl[i]=0 如果 str[i] = 'b' ,  bl[i]=bl[i-1]+1, rl[i]=0 如果 str[i] = 'w',  bl[i]=b