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 前段时间做过一道一样的题,这类题基本套路二分找没删除前的位置 ...
随机推荐
- Maven多模块工程打包指定模块工程方法
Maven多模块工程打包指定模块工程执行如下命令: mvn clean package -pl 指定模块工程名 -am 参数说明: -am --also-make 同时构建所列模块的依赖模块:-am ...
- JobStorage.Current property value has not been initialized. You must set it before using Hangfire Client or Server API.
JobStorage.Current property value has not been initialized. You must set it before using Hangfire Cl ...
- c# socket 心跳 重连
/// <summary> /// 检查一个Socket是否可连接 /// </summary> /// <param name="socket"&g ...
- 使用HOSTNAMECTL配置主机名
hostnamectl工具是用来管理给定主机中. 查看所有主机名 请运行下面的命令查看所有当前主机名: 〜] $ hostnamectl status 如果未指定任何选项,默认则使用status选项对 ...
- django使用https
根据以下内容总结了下: http://www.voidcn.com/article/p-xxdfvetx-da.html http://www.voidcn.com/article/p-ezmbnny ...
- day08——文件操作
day08 文件操作: open() :打开 f (文件句柄)= open("文件的路径(文件放的位置)",mode="操作文件的模式",encoding=&q ...
- ASP.NET WebApi 学习与实践系列(2)---WebApi 路由请求的理解
目录 写在前面 WebApi Get 请求 1.无参数的请求 2.一个参数的请求 3.多个参数的请求 4.实体参数的请求 WebApi Post 请求 1.键值对请求 2.dynamic 动态类型请求 ...
- 阿里云ESC服务器配置记录
购买服务器 上周赶着活动购买了一年阿里云服务器,记录一下配置过程: 选择服务器类型: linux服务器,网上说一般都用centOS的"比较新"的版本: 重置密码: 重置密码之后一定 ...
- 自学Python编程的第十天(希望有IT大牛看见的指点小弟我,万分感谢)---------来自苦逼的转行人
2019-09-20-23:24:15 今天逛论坛.逛知识星球时.逛b站up主时,都说到低学历,非科班的人最好不要去自学Python 他们都说:如果我们学python是为了找工作,最好不要把pytho ...
- MySql表、字段、库的字符集修改及查看方法
这篇文章主要介绍了MySql表.字段.库的字符集修改及查看方法,本文分别给们它的修改及查看语句,需要的朋友可以参考下 修改数据库字符集: 代码如下: ALTER DATABASE db_name DE ...