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 前段时间做过一道一样的题,这类题基本套路二分找没删除前的位置 ...
随机推荐
- 关闭正在执行的事务 Kill
.模拟资源锁定 --开始事务BEGIN TRANSACTION--更新数据update Table_1 set FuncName=FuncName--等待1分钟WAITFOR DELAY '01:00 ...
- Docker 两键创建 ZeroTier moon 节点
一条命令创建 ZeroTier moon 节点: $ docker run --name zerotier-moon -d -p 9993:9993 -p 9993:9993/udp seedgou/ ...
- .net桌面程序或者控制台程序使用NLog时的注意事项
Nuget添加NLog 添加nlog.config文件,并选择属性->始终复制 不选择始终复制,编译后nlog.config是没有的. 具体使用: private static readonly ...
- 【Python】解决使用pyinstaller打包Tkinker程序报错问题
问题描述 使用pyinstaller打包使用Tkinter编写的控制台程序,出现报错 15793 INFO: Adding Microsoft.Windows.Common-Controls to d ...
- 【jquery】【ztree】节点添加自定义按钮、编辑和删除事件改成自己定义事件
setting添加 edit: { drag: { isCopy: false, isMove: true }, enable: true,//设置是否处于编辑状态 showRemoveBtn: sh ...
- Java操作fastDFS
一.加入Maven依赖 <dependency> <groupId>org.csource</groupId> <artifactId>fastdfs- ...
- STM32学习笔记 —— 1.1 什么是寄存器(概念分析)
问题引入: 用一句话回答以下问题: 什么是寄存器? 什么是寄存器映射? 什么是存储器映射? (本章重点在 1.1.3 和 1.1.4) 1.1 STM32芯片实物图 (图) 学会看丝印图 芯片型号.内 ...
- Glances - Linux上的实时系统监控工具(Centos安装)
Glances WebServer 模式 在 glances 的 WebServer 模式下,客户端只通过浏览器访问就可以获取远程服务器的运行状态. 安装成功后,使用 glances -w 命令即可 ...
- (1)ASP.NET Core 应用启动Startup类简介
1.前言 Core与早期版本的 ASP.NET 对比,配置应用程序的方式的 Global.asax.FilterConfig.cs和RouteConfig.cs 都被Program.cs 和 Star ...
- CentOs7.3 搭建 SolrCloud 集群服务
一.概述 Lucene是一个Java语言编写的利用倒排原理实现的文本检索类库: Solr是以Lucene为基础实现的文本检索应用服务.Solr部署方式有单机方式.多机Master-Slaver方式.C ...