zoukankan      html  css  js  c++  java
  • Music

    题目链接:http://acm.hust.edu.cn/vjudge/problem/visitOriginUrl.action?id=111966
    题意:

          小莉莎喜欢用她的智能手机听歌,但这一手机没有太多内存,所以她通过社交网络下载来听她最爱的歌。但网络不好,而且需要花费长时间来下载。幸好莉莎很耐心。

          已知一首歌曲的长度为T秒,当下载完开始的S秒时,莉莎开始听歌。当下载未完成而莉莎已经听完下载部分时,莉莎又从头开始听歌。对于q秒长的时间,网络允许下载歌曲长度为q-1秒。你的任务是计算出一首歌下载完的时间里,莉莎从头听歌的次数。 (2 ≤ q ≤ 104, 1 ≤ S < T ≤ 105)

    案例:  

          Sample Input

          Input
      5 2 2
         Output
      2
         Input
      5 4 7
         Output
      1
         Input
      6 2 3
         Output
      1
    
    分析:
          该题类似于追赶相遇问题,可以转化为:
    A站到B站的距离为T,一波人从A站出发去B站,首先甲先出发,当他走出离A站距离为S时,A站的乙同时出发,直至乙赶上甲后,若甲仍未抵达B站,
    A站里的丙又开始出发追击甲,若甲仍未抵达B站,再又丁从A站出发追击甲,如此反复,直至甲抵达B站。已知甲的速度为每q秒前进(q-1),问甲抵达B
    站时,A站出发了多少人(不包括甲)。
    这样就很容易理解题意,同时建议画图,这样更容易看出求解过程。
    假设乙追上甲时,甲前行了X,乙前行了Y,则有Y=S+X=S+Y/q*(q-1)。化简有Y=S*q,若甲此时仍未抵达终点,则循环上述过程,而需注意的是S
    已经转变为上一步的Y!
    源代码:
     1 #include<cstdio>
     2 int T,S,q,count=0;
     3 int main()
     4 {
     5     scanf("%d%d%d",&T,&S,&q);
     6     int sum=S;//记录歌曲下载长度
     7     while(sum<T)
     8     {
     9         ++count;
    10         sum=q*sum;
    11     }
    12     printf("%d
    ",count);
    13     return 0;
    14 }
  • 相关阅读:
    【转】C# 注册表简单操作
    [转]VC++之随父窗口变化调整控件大小/位置
    [转]vc 汉字汉语拼音首字母如何获取
    [转]浅析ActiveX控件的CAB压缩
    [转]VC6.0中使用MFC开发ActiveX及简单验证
    ElasticSearch增加索引字段
    单词缩写
    linux命令
    使用PR插件Twixtor Pro对视频补帧
    Linux创建脚本服务
  • 原文地址:https://www.cnblogs.com/huaszjh/p/4749875.html
Copyright © 2011-2022 走看看