Educational Codeforces Round 8 C. Bear and String Distance 贪心
C. Bear and String Distance
题目连接:
http://www.codeforces.com/contest/628/problem/C
Description
Limak is a little polar bear. He likes nice strings — strings of length n, consisting of lowercase English letters only.
The distance between two letters is defined as the difference between their positions in the alphabet. For example, , and .
Also, the distance between two nice strings is defined as the sum of distances of corresponding letters. For example, , and .
Limak gives you a nice string s and an integer k. He challenges you to find any nice string s' that . Find any s' satisfying the given conditions, or print "-1" if it's impossible to do so.
As input/output can reach huge size it is recommended to use fast input/output methods: for example, prefer to use gets/scanf/printf instead of getline/cin/cout in C++, prefer to use BufferedReader/PrintWriter instead of Scanner/System.out in Java.
Input
The first line contains two integers n and k (1 ≤ n ≤ 105, 0 ≤ k ≤ 106).
The second line contains a string s of length n, consisting of lowercase English letters.
Output
If there is no string satisfying the given conditions then print "-1" (without the quotes).
Otherwise, print any nice string s' that .
Sample Input
4 26
bear
Sample Output
roar
Hint
题意
现在定义了一个dis(a,b),dis(a,b) = abs(a-b),等于这两个数的ASCII码的距离
然后现在给你一个串,让你构造另外一个串,使得这两个串之间的距离和恰好等于k
题解:
贪心,我们暴力向最远的地方靠就好了
代码
#include<bits/stdc++.h>
using namespace std;
string s,s1;
int main()
{
    int n,k;
    cin>>n>>k;
    cin>>s;
    for(int i=0;i<s.size();i++)
    {
        int dis1 = 'z'-s[i];
        int dis2 = s[i]-'a';
        if(dis1>dis2)
        {
            int ddd = min(dis1,k);
            k-=ddd;
            s1+=s[i]+ddd;
        }
        else
        {
            int ddd = min(dis2,k);
            k-=ddd;
            s1+=s[i]-ddd;
        }
    }
    if(k)return puts("-1");
    else cout<<s1<<endl;
}												
											Educational Codeforces Round 8 C. Bear and String Distance 贪心的更多相关文章
- Educational Codeforces Round 9 C. The Smallest String Concatenation —— 贪心 + 字符串
		
题目链接:http://codeforces.com/problemset/problem/632/C C. The Smallest String Concatenation time limit ...
 - [Educational Codeforces Round 16]E. Generate a String
		
[Educational Codeforces Round 16]E. Generate a String 试题描述 zscoder wants to generate an input file f ...
 - Educational Codeforces Round 16 E. Generate a String dp
		
题目链接: http://codeforces.com/problemset/problem/710/E E. Generate a String time limit per test 2 seco ...
 - Educational Codeforces Round 9 C. The Smallest String Concatenation 排序
		
C. The Smallest String Concatenation 题目连接: http://www.codeforces.com/contest/632/problem/C Descripti ...
 - Educational Codeforces Round 8 F. Bear and Fair Set 最大流
		
F. Bear and Fair Set 题目连接: http://www.codeforces.com/contest/628/problem/F Description Limak is a gr ...
 - Educational Codeforces Round 16 E. Generate a String (DP)
		
Generate a String 题目链接: http://codeforces.com/contest/710/problem/E Description zscoder wants to gen ...
 - Educational Codeforces Round 40 I. Yet Another String Matching Problem
		
http://codeforces.com/contest/954/problem/I 给你两个串s,p,求上一个串的长度为|p|的所有子串和p的差距是多少,两个串的差距就是每次把一个字符变成另一个字 ...
 - Educational Codeforces Round 9 C. The Smallest String Concatenation(字符串排序)
		
You're given a list of n strings a1, a2, ..., an. You'd like to concatenate them together in some or ...
 - Educational Codeforces Round 62 (Rated for Div. 2) C 贪心 + 优先队列 + 反向处理
		
https://codeforces.com/contest/1140/problem/C 题意 每首歌有\(t_i\)和\(b_i\)两个值,最多挑选m首歌,使得sum(\(t_i\))*min(\ ...
 
随机推荐
- peepscan前期准备工作
			
具有的功能 1.whoami 2.sub doamin https://dns.aizhan.com/huayi-faucet.com/ 3.dir scan 4.web server 5.port ...
 - linux pthread【转】
			
转自:http://www.cnblogs.com/alanhu/articles/4748943.html Posix线程编程指南(1) 内容: 一. 线程创建 二.线程取消 关于作者 线程创 ...
 - VPS L2TP配置
			
原文地址:https://raymii.org/s/tutorials/IPSEC_L2TP_vpn_with_Ubuntu_14.04.html 只要保证ipsec verify没错,基本都可以成功 ...
 - gradle问题总结与理解(一篇文章带你理解android studio 与gradle 的关系)
			
前言:近日在网上找了个很不错的安卓二维码美化,由于下载的项目经常出问题,且不方便依赖使用,因此我想把它写个demo,并把源码发布到jcenter中,修改还是很顺利的,运行项目到手机也没问题,发布遇到了 ...
 - VPS性能测试(2):内存大小、交换空间、高速缓存、实际使用内存
			
1.要想查看购买的VPS主机的内存信息,执行:cat /proc/meminfo,主要是看内存大小.交换空间.高速缓存 2.VPS主机实际使用内存大小.Linux管理内存的机制是这样的:无论物理内存有 ...
 - js前端数据加密插件
			
(2014-11-14 15:37:35) 转载▼ 标签: it 分类: Web前端开发 摘要: 大部分动态网站都支持从客户端到服务器传递数据,如果传递的数据被别人截取就非常危险,尤其是一些用户名密码 ...
 - jQuery 中的 unbind() 方法
			
jQuery 中的 unbind() 方法是 bind() 方法的反向操作,从每一个匹配的元素中删除绑定的事件. 语法结构: unbind([type][, data]); type是事件类型,dat ...
 - Leetcode 之Length of Last Word(37)
			
扫描每个WORD的长度并记录即可. int lengthOfLast(const char *s) { //扫描统计每个word的长度 ; while (*s) { if (*s++ != ' ')/ ...
 - CF914F Substrings in a String
			
Description 给你一个字符串ss,共有qq次操作,每个都是下面两种形式的一种. 11 ii cc 这个操作表示将字符串ss的第ii项变为字符cc 22 ll rr yy 这个操作表示输出字符 ...
 - javascript 实现图片轮播和点击切换功能
			
图片轮播是网页上一个比较常见的功能,下面我们来实现他吧 原理很简单: 1:固定的区域,所有的图片重叠,一次只能显示一张图片 2:通过改变图片的zIndex属性改变显示的图片,就可以达到切换的效果了 & ...