Codeforces I. Inna and Nine(组合)
题目描述:
Inna and Nine
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output
Inna loves digit 9 very much. That's why she asked Dima to write a small number consisting of nines. But Dima must have misunderstood her and he wrote a very large number a, consisting of digits from 1 to 9.
Inna wants to slightly alter the number Dima wrote so that in the end the number contained as many digits nine as possible. In one move, Inna can choose two adjacent digits in a number which sum equals 9 and replace them by a single digit 9.
For instance, Inna can alter number 14545181 like this: 14545181 → 1945181 → 194519 → 19919. Also, she can use this method to transform number 14545181 into number 19991. Inna will not transform it into 149591 as she can get numbers 19919 and 19991 which contain more digits nine.
Dima is a programmer so he wants to find out how many distinct numbers containing as many digits nine as possible Inna can get from the written number. Help him with this challenging task.
Input
The first line of the input contains integer a (1 ≤ a ≤ \(10^{100000}\)). Number a doesn't have any zeroes.
Output
In a single line print a single integer — the answer to the problem. It is guaranteed that the answer to the problem doesn't exceed \(2^{63 - 1}\).
Please, do not use the %lld specifier to read or write 64-bit integers in С++. It is preferred to use the cin, cout streams or the %I64d specifier.
Examples
Input
Copy
369727
Output
Copy
2
Input
Copy
123456789987654321
Output
Copy
1
Input
Copy
1
Output
Copy
1
Note
Notes to the samples
In the first sample Inna can get the following numbers: 369727 → 99727 → 9997, 369727 → 99727 → 9979.
In the second sample, Inna can act like this: 123456789987654321 → 12396789987654321 → 1239678998769321.
思路:
题目是要给一个数字串,两个相邻的数字加起来是9的话可以合并,问在9最多的情况下最多可以得到多少种不同的数字串。
刚开始看这道题看起来非常麻烦,这个,,,怎么做,我要怎么找有几个加起来等于9还不同的情况,确定一个什么策略可以区分并尝试加成不同的数,一个一个试?递归?动态规划?看一眼数据范围,直接10^5,限时一秒枚举不够啊。这就说明有更简洁的方法。
只能一个一个找规律了。
我们现看看样例14545181,这个九要最多,只能19991或19919,也就是说中间的4545刚好组成两个9就不能拆开,拆开会少。那么什么情况下会有多种可能呢?我们把注意力转向181,就是这个产生了两种可能。
我们便发现,要想有多种可能,必须满足一个性质:一个数和左边加起来是9,和右边加起来也是9
举个栗子:1454541
我们发现两边的1对结果毫无影响,因为它们并不能凑一个9出来,于是去掉,得到45454,这有几种情况呢?994,949,499三种,这个串里面我们发现刚好有5,4,5这三个数满足上面的性质
再来:454,有94和49两种,有5一个数满足上面的性质
数在长一点:4545454有4999,9499,9949,9994四种,满足上述性质的串中的数有5,4,5,4,5这五个
要是长度为偶数呢?4545,我们发现只有99一种可能,而其中满足性质的有5,4两个数
发现规律没有?只有当满足性质的数有奇数个,才有多种可能,偶数个只可能为一
而且满足性质的数和产生的可能性有如下关系:\(a_n=(n+3)/2\),\(n\)为满足性质的数的个数,且为奇数,\(a_n\)为可能的种数。
现在问题只剩下如何识别具有这种模式的串中数字的个数。就按性质来识别就好了,遍历除开头结尾的每个数,看是不是满足性质,是就把个数加一。注意的是满足性质的字串不一定是连续的,串断裂后及时把计数变量清零。还有注意个数为偶数的情况并不贡献可能性。
代码:
#include <iostream>
#include <string>
using namespace std;
string s;
long long judge(string s)
{
long long ans = 1;
long long num = 0;
for(int i = 1;i<s.size()-1;i++)
{
if(s[i-1]+s[i]-2*'0'==9&&s[i]+s[i+1]-2*'0'==9)
{
num++;
}
else if(num%2==1)
{
ans = ans*((num+3)/2);
//cout << "num " << num << endl;
num = 0;
}
else
{
num = 0;
}
}
if(num%2==1)
{
ans = (ans*(num+3)/2);
}
return ans;
}
int main()
{
cin >> s;
long long ans = judge(s);
cout << ans << endl;
return 0;
}
Codeforces I. Inna and Nine(组合)的更多相关文章
- codeforces 374A Inna and Pink Pony 解题报告
题目链接:http://codeforces.com/problemset/problem/374/A 题目意思:给出一个 n 行 m 列 的棋盘,要将放置在坐标点为(i, j)的 candy 移动 ...
- Codeforces 374A - Inna and Pink Pony
原题地址:http://codeforces.com/contest/374/problem/A 好久没写题目总结了,最近状态十分不好,无论是写程序还是写作业还是精神面貌……NOIP挂了之后总觉得缺乏 ...
- CodeForces 400A Inna and Choose Options
Inna and Choose Options Time Limit: 1000ms Memory Limit: 262144KB This problem will be judged on Cod ...
- codeforces 499A.Inna and Pink Pony 解题报告
题目链接:http://codeforces.com/problemset/problem/499/A 题目意思:有两种按钮:1.如果当前观看的时间是 t,player 可以自动处理下一分钟,姑且理解 ...
- Codeforces 374B - Inna and Nine
原题地址:http://codeforces.com/problemset/problem/374/B 这道题没什么难度,但是考场上就是没写对.Round #220彰显了它的逗比性质——这道题的“标算 ...
- codeforces C. Inna and Huge Candy Matrix
http://codeforces.com/problemset/problem/400/C 题意:给你一个n*m的矩阵,然后在矩阵中有p个糖果,给你每个糖果的初始位置,然后经过x次顺时针反转,y次旋 ...
- Codeforces.1096E.The Top Scorer(组合)
题目链接 感觉这题很裸啊,除了看着恶心点也没什么了,怎么过的人那么少.. \(Description\) 给定\(n,r,s\),表示有\(n\)个人,设每个人的得分是非负整数\(a_i\),已知第一 ...
- Codeforces 374C - Inna and Dima
374C - Inna and Dima 思路:dfs+记忆化搜索 代码: #include<bits/stdc++.h> using namespace std; #define ll ...
- Codeforces 374D - Inna and Sequence
374D - Inna and Sequence 思路: 树状数组+二分 因为被删的点最多N=1e6个,所以复杂度N*logN*logN 前段时间做过一道一样的题,这类题基本套路二分找没删除前的位置 ...
随机推荐
- linux服务器之间文件传输
有时候我们会遇到,把一个服务器上的文件夹,传到另一个服务器 我们需要先把文件夹打包成 tar.gz,这种格式在任何linux版本上都能压缩/解压 #解压命令 tar -zxvf xxx.tar.gz ...
- cube-ui 重构饿了吗Webapp的 scroll-nav域名插槽问题
Vue2.6 将 slot-scope 废弃了. 推荐使用 v-slot: 其使用方法大致如下: 注意多个插槽的情况下,最好都基于 <template> default插槽用法还是一样的, ...
- 湖南省第6届程序大赛第6题 Biggest Number
Problem F Biggest Number You have a maze with obstacles and non-zero digits in it: You can start fro ...
- python语法入门之变量
目录 一.变量 1.1 什么是变量 1.2 怎么使用变量 1.3 变量名的命名规范 1.4 变量名的命名风格 1.5 变量的三大特征 2.常量 一.变量 1.1 什么是变量 # 变量就是可以变化的量, ...
- 【洛谷5537】【XR-3】系统设计(哈希_线段树上二分)
我好像国赛以后就再也没有写过 OI 相关的博客 qwq Upd: 这篇博客是 NOIP (现在叫 CSP 了)之前写的,但是咕到 CSP 以后快一个月才发表 -- 我最近这么咕怎么办啊 -- 题目 洛 ...
- Idea 目录结构下有红色波浪线
问题截图: 解决方案: Build -> Rebuild Project
- go 指针 通过指针修改int类型的值
指针的定义 :var p *int 取指针的值 :*p ------------------------------------------------------------------------ ...
- RSA非对称 私钥加密
RSA生成公钥和私钥对 /// <summary> /// RSA生成公钥和私钥 /// </summary> /// <returns></returns& ...
- C# vb .net实现大小调整特效滤镜
在.net中,如何简单快捷地实现Photoshop滤镜组中的大小调整效果呢?答案是调用SharpImage!专业图像特效滤镜和合成类库.下面开始演示关键代码,您也可以在文末下载全部源码: 设置授权 第 ...
- 1.java小作业-计算1到100的整合-指定输入多少行输出就打印多少行-打印24小时60分钟每一分钟-重载基础练习-面向java编程初学者
可能有和我一样刚开始学习java的小伙伴们, 可以或多或少了解一点别的语言知识,我就是中途转过来的, 明白一点,关键不在语言本身····· 所以面对初学者来说,基础要学好, 下面列举几个没什么难度的小 ...