• [HEOI2015]定价


    题目描述

    在市场上有很多商品的定价类似于 999 元、4999 元、8999 元这样。它们和 1000 元、5000 元和 9000 元并没有什么本质区别,但是在心理学上会让人感觉便宜很多,因此也是商家常用的价格策略。不过在你看来,这种价格十分荒谬。于是你如此计算一个价格 p(p 为正整数)的荒谬程度:

    1、首先将 p 看做一个由数字组成的字符串(不带前导 0);

    2、然后,如果 p 的最后一个字符是 0,就去掉它。重复这一过程,直到 p 的最后一个字符不是 0;

    3、记 p 的长度为 a,如果此时 p 的最后一位是 5,则荒谬程度为 2 * a - 1;否则为 2 * a。

    例如,850 的荒谬程度为 3,而 880 则为 4,9999 的荒谬程度为 8。

    现在,你要出售一样闲置物品,你能接受的定价在 [L, R] 范围内,你想要给出一个荒谬度最低的价格。

    输入输出格式

    输入格式:

    输入文件的第一行包含一个正整数 T,表示测试数据的数目。

    每个测试数据占单独的一行,包含两个空格分隔的正整数 L, R,表示定价的区间。

    输出格式:

    对于每个测试数据,在单独的一行内输出结果。如果荒谬度最低的价格不唯一,输出最小的那个。

    输入输出样例

    输入样例#1: 
    3
    998 1002
    998 2002
    4000 6000
    输出样例#1: 
    1000
    1000
    5000

    说明

    对于 20% 的数据,L, R ≤ 2000.

    对于 100% 的数据,T ≤ 100,1 ≤ L ≤ R ≤ 10^9.

    这个题难道不是小学生难度的吗2333,直接按位贪心就行了,,,亏我还一开始写挂了2333

    #include<bits/stdc++.h>
    #define ll long long
    using namespace std;
    int T,L,R,mn,num;
    int l,r,now,w,v;
    int ci[12];
    
    inline int getlen(int x){
    	int an=0;
    	while(x) an++,x/=10;
    	return an;
    }
    
    int main(){
    	ci[0]=1;
    	for(int i=1;i<=9;i++) ci[i]=ci[i-1]*10;
    	scanf("%d",&T);
    	while(T--){
    		mn=1<<30,now=0;
    		scanf("%d%d",&L,&R);
    		for(;L<=R;now++){
    			l=L%10;
    			
    			v=L-l+5;
    			if(v<L||v>R) v=L;
    			w=getlen(v)*2+(v%10==5?-1:0);
    			if(w<mn||(w==mn&&v*ci[now]<num)) mn=w,num=v*ci[now];
    			
    			L=L/10+(l?1:0),R=R/10;
    		}
    		printf("%d
    ",num);
    	}
    	
    	return 0;
    }
    

      

  • 相关阅读:
    基于麦克风阵列的声源定位算法之GCC-PHAT
    Parametric and Non-parametric Algorithms
    MATLAB中运算符优先级
    [HAOI2018]染色
    [SHOI2016]黑暗前的幻想乡
    [SCOI2012]滑雪
    [PA2014]Kuglarz
    Stroll
    [SDOI2010]大陆争霸
    解决IDEA Gradle构建报错"Cause: zip END header not found"
  • 原文地址:https://www.cnblogs.com/JYYHH/p/8551932.html
Copyright © 2020-2023  润新知