Codeforces #262 (Div. 2) A. Vasya and Socks(水题)

A. Vasya and Socks
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

Vasya has n pairs of socks. In the morning of each day Vasya has to put on a pair of socks before he goes to school. When he comes home in the evening, Vasya takes off the used socks and throws them away. Every m-th day (at days with numbers m, 2m, 3m, ...) mom buys a pair of socks to Vasya. She does it late in the evening, so that Vasya cannot put on a new pair of socks before the next day. How many consecutive days pass until Vasya runs out of socks?

Input

The single line contains two integers n and m (1 ≤ n ≤ 100; 2 ≤ m ≤ 100), separated by a space.

Output

Print a single integer — the answer to the problem.

Sample test(s)
input
2 2
output
3
input
9 3
output
13
Note

In the first sample Vasya spends the first two days wearing the socks that he had initially. Then on day three he puts on the socks that were bought on day two.

In the second sample Vasya spends the first nine days wearing the socks that he had initially. Then he spends three days wearing the socks that were bought on the third, sixth and ninth days. Than he spends another day wearing the socks that were bought on the twelfth day.




一道大水题,因为太着急了,所以刚写的时候细节没有考虑清楚

对于7 2这组数据

正确的结果应该是:13

ans += 7/2×2 == 6

tmp = 7/2+7%2 = 4

ans += 4/2×2 == 10

tmp = 4/2+4%2 = 2

ans += 2/2×2 == 12

tmp = 2/2+2%2 = 1

ans += 1 == 13

保存每次计算剩余的数量tmp是关键

代码如下:

#include <bits/stdc++.h>
using namespace std;

int main(void) {
    int n, m, tmp, ans, cnt;
    cin >> n >> m;
    if(n < m) {
        cout << n << endl;
        return 0;
    }
    ans = n/m*m;
    tmp = n;
    while(tmp >= m) {
        tmp = tmp/m+tmp%m;
        ans += tmp/m*m;
    }
    if(tmp != n)
        ans += tmp;
    cout << ans << endl;

    return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值