TCO 2016 Round 1B
problem 250
Problem Statement
Vasa likes to construct sequences of numbers. If you tell him a positive integer n, he will begin a new sequence by writing the integer n as its first element. He will then repeat the following steps:
- If the last number in his sequence is a prime, he terminates the sequence.
- If he already wrote n elements without finding a prime, he becomes bored and leaves.
- Otherwise, he computes the next element of the sequence as the sum of squares of digits of the last element. For example, 4001 will be followed by 4^2 + 0^2 + 0^2 + 1^2 = 17, and 17 will be followed by 1^2 + 7^2 = 50.
Find out what happens for the given int n. If Vasa eventually becomes bored and leaves, return -1. Otherwise, return the length of the generated sequence.
Definition
- ClassExploringNumbers
- MethodnumberOfSteps
- Parametersint
- Returnsint
- Method signatureint numberOfSteps(int n)
Limits
- Time limit (s)2.000
- Memory limit (MB)256
Notes
- A prime number is a positive integer with exactly two positive integer divisors: 1 and itself. The first few primes are 2, 3, 5, 7, 11. Note that 1 is not a prime.
Constraints
- n will be between 1 and 10^9, inclusive.
Test cases
- n5
Returns1
The input itself is a prime.- n57
Returns4
Vasa will write down 57, 74 (= 5^2 + 7^2), 65 (= 7^2 + 4^2), and 61 (= 6^2 + 5^2). Number 61 is a prime.- n1
Returns-1
Vasa begins by writing down the number 1. As 1 is not a prime, he is not done yet. As he already wrote down 1 element of the sequence without finding a prime, he becomes bored and leaves.- n6498501
Returns2
- n989113
Returns6
- n12366
Returns-1
For n=12366 there are no primes among the first 12366 elements of Vasa's sequence.
暴力循环一下就行了。再记录一下当前这个数在之前计算过没有,如果计算过了那么久返回-1
#include <cstdio>
#include <cmath>
#include <cstring>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <set>
#include <vector>
#include <sstream>
#include <typeinfo>
#include <fstream>
#include <map>
using namespace std; class ExploringNumbers {
public:
int check(int x){
if(x==)return ;
for(int i=;i*i<=x;i++){
if(x%i==)return ;
}
return ;
}
int numberOfSteps(int n) {
map<int,int>mp;
int ans=;
int m=n;
if(n==)return -;
if(check(n))return ;
int sum;
int mark=;
while(check(n)==){
ans++;
sum=;
mp[n]=;
while(n>){
int a=n%;
n/=;
sum+=a*a;
}
n=sum;
if(mp[n]||ans>m){
mark=;break;
}
}
if(mark)return -;
return ans;
}
};
problem 500
Problem Statement
Vasa is a shopkeeper in the small town Deronje. Currently, there are some items for sale in his store. The price of each item is a positive integer. You are given these prices in the int[] A. Each item has a price tag.
Vasa has just learned that a very rich shopper is going to visit his store. Therefore, Vasa wants to alter some of the price tags to make the items in his store more expensive.
Vasa has a collection of stickers. Each of those stickers contains a single digit between 1 and 9, inclusive. Note that he has no stickers with zeros. You are given the description of Vasa's stickers in the int[] D. For each i between 1 and 9, inclusive, Vasa has D[i-1] stickers with the digit i.
Vasa can take any sticker and use it to replace any digit on any price tag. However, there is no extra room on the price tags, so he cannot add new digits, he can only replace existing ones.
Compute and return the maximum total cost of items in Vasa's store after he applies some (possibly none, possibly all) of his stickers to the current price tags.
Definition
- ClassReplacingDigit
- MethodgetMaximumStockWorth
- Parametersvector<int> , vector<int>
- Returnsint
- Method signatureint getMaximumStockWorth(vector<int> A, vector<int> D)
Limits
- Time limit (s)2.000
- Memory limit (MB)256
Constraints
- A will contain between 1 and 50 elements, inclusive.
- Each element of A will be between 1 and 10^6, inclusive.
- D will contain exactly 9 elements.
- Each element of D will be between 0 and 10^3, inclusive.
Test cases
- A{ 100, 90 }
- D{ 0, 0, 0, 0, 2, 1, 0, 0, 0 }
Returns745
Vasa has two digit stickers with digit 5 written on them, and one digit sticker with digit 6 written on it. There are two items in the shop: one with price 100, and the other one with price 90.
Vasa can use one digit sticker with 5 to replace digit 0 of price tag 90 obtaining a new price of 95 of that item. Then, he can use the remaining stickers 5 and 6 to change the price tag of the other item from 100 to 650. In that case, the worth of his stock would be 650 + 95 = 745.
Note that the same stock worth could be obtained by applying all the three digit stickers to 100 in order to obtain a new price of 655. In that case, the price 90 of the other item would remain unchanged.
- A{ 9 }
- D{ 1, 1, 1, 1, 1, 1, 1, 1, 0 }
Returns9
In this example, the maximum stock worth is obtained by leaving the price tag unchanged. Note that Vasa is not required to use all stickers.
- A{ 123456 }
- D{ 9, 8, 7, 6, 5, 4, 3, 2, 1 }
Returns988777
- A{ 10, 970019, 1976, 10936, 68750, 756309, 37600, 559601, 6750, 76091, 640, 312, 312, 90, 8870 }
- D{ 11, 2, 8, 10, 7, 6, 3, 1, 3 }
Returns3297500
- A{ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 }
- D{ 111, 111, 111, 111, 111, 111, 111, 111, 111 }
Returns198
题意就是现在你有1~9这9个数,每个数有D[i]个,然后让你用这9个数 代替 A集合中的数字的某些位,使得最后A集合中的数的和最大。贪心思想。以9,8,7....1的顺序 从最高位开始改。
#include <cstdio>
#include <cmath>
#include <cstring>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <set>
#include <vector>
#include <sstream>
#include <typeinfo>
#include <fstream>
#define INF 2000000000
#define ll long long
using namespace std; class ReplacingDigit {
public:
int getMaximumStockWorth(vector<int> A, vector<int> D) {
sort(A.begin(),A.end());
vector<int>v[];
int n=A.size();
for(int i=;i<n;i++){
while(A[i]>){
int a=A[i]%;
v[i].push_back(a);
A[i]/=;
}
}
for(int i=D.size()-;i>=;i--){
while(D[i]>){
int mark=;
for(int t=;t>=;t--){
int ans=INF;
int id;
for(int j=;j<n;j++){
if(v[j].size()>=t){
if(v[j][t-]<ans){
ans=v[j][t-];
id=j;
}
}
}
if(ans<i+){
v[id][t-]=i+;
D[i]--;
mark=;
break;
}
}
if(mark==)break;
}
}
ll sum=;
for(int i=;i<n;i++){
int t=;
for(int j=;j<v[i].size();j++){
sum+=t*v[i][j];
t*=;
}
}
return sum;
}
};
理论上来说做了2题.坑爹的网络,第二题没有提交上..
TCO 2016 Round 1B的更多相关文章
- Google Code Jam 2016 Round 1B B
题意:给出两个数字位数相同,分别中间有若干位不知道,用问号表示.现在要求补全这两个数字,使得差值的绝对值最小,多解则取第一个数字的值最小的,再多解就取第二个数字最小的. 分析: 类似数位dp,但是很多 ...
- TCO 2015 Round 1B DIV1 500 概率题
[题意]现在有一些线索,每个线索被发现的概率p[i],如果线索i被知道,那么其他线索也可能会被知道,用vector<string> c给出,c[i][j]='Y'表示知道i这个线索,j这个 ...
- Google Code Jam 2016 Round 1B Problem C. Technobabble
题目链接:https://code.google.com/codejam/contest/11254486/dashboard#s=p2 大意是教授的学生每个人在纸条上写一个自己的topic,每个to ...
- 2019 TCO Round 1B——[ 状压DP ]
第一题是 EllysSki . 题意:给n个数,求两个方向的最长递减区间. 可以O(n). #include<cstdio> #include<cstring> #includ ...
- TCO 2014 Round 1C 概率DP
TCO round 1C的 250 和500 的题目都太脑残了,不说了. TCO round 1C 950 一个棋子,每次等概率的向左向右移动,然后走n步之后,期望cover的区域大小?求cover, ...
- Codeforces Round #351 (VK Cup 2016 Round 3, Div. 2 Edition) B. Problems for Round 水题
B. Problems for Round 题目连接: http://www.codeforces.com/contest/673/problem/B Description There are n ...
- Codeforces Round #351 (VK Cup 2016 Round 3, Div. 2 Edition) B
B. Problems for Round time limit per test 2 seconds memory limit per test 256 megabytes input standa ...
- VK Cup 2016 - Round 1 (Div. 2 Edition) C. Bear and Forgotten Tree 3
C. Bear and Forgotten Tree 3 time limit per test 2 seconds memory limit per test 256 megabytes input ...
- Codeforces Round #351 (VK Cup 2016 Round 3, Div. 2 Edition)只有A题和B题
连接在这里,->点击<- A. Bear and Game time limit per test 2 seconds memory limit per test 256 megabyte ...
随机推荐
- bzoj 5110 Yazid的新生舞会
题目大意: 一个数列,求有多少个区间$[l,r]$满足该区间的众数出现次数大于$\lceil \frac{r-l}{2} \rceil$ 思路: 对于一个区间满足条件的众数明显是唯一的 所以设该数的前 ...
- 如何将一个int转换成cstring
如:int a = 5;CString b;b.Format("%d",a);补充:如果a是double,或a是float的就是:b.Format("%f",a ...
- CI(CodeIgniter)框架中的增删改查操作
我们创建一个模型( 项目目录/models/),请注意:模型名与文件名相同且必须继承数据核心类CI_Model,同时重载父类中的构造方法 CodeIgniter的数据函数类在 \models\User ...
- android开发里跳过的坑——camera调用setDisplayOrientation设置预览显示旋转无效
问题原因,在surfaceview没有设置给camera之前调用了,所以,这个方法一定要在camera.setPreviewDisplay(surfaceHolder)这个之后,启动相机预览之前调用.
- html-Span 指定宽度
html-Span 指定宽度 css: span{ display:-moz-inline-box; display:inline-block; width:150px; } 链接:如何设置HTML ...
- 数据库数据导出CSV文件,浏览器下载
直接上代码: def download(request): # 从数据库查询数据 data_list = Info.objects.all() # 定义返回对象 response = HttpResp ...
- cssnext下一代的css
前端技术更新迭代的速度令人咂舌,互联网+的风头刚起那几年,前端技术大多还停留在jquery阶段,按需加载还停留在seajs和requirejs的阶段,css3和H5也不过才崭露头角,但经过几年的飞速发 ...
- ffmpeg实时编码解码部分代码
程序分为编码端和解码端,两端通过tcp socket通信,编码端一边编码一边将编码后的数据发送给解码端.解码端一边接收数据一边将解码得到的帧显示出来. 代码中的编码端编码的是实时屏幕截图. 代码调用 ...
- weexpack 的 Login.vue 及 vue 的 Login.vue
1.登录页 weexpack Login.vue <!-- 登录页 --> <template> <div class="wrapper"> ...
- WMS8_仓库配置
仓库划分为不同的区域,比如收货区,出货区,库存区,这些区域在odoo中称之为库位[location],库位可以上下嵌套,形成一个树状的层级关系. 库位分为不同的类型 物理库存位置[Physical s ...