zoukankan      html  css  js  c++  java
  • Casting

    Casting
    Time Limit: 3000ms, Special Time Limit:7500ms, Memory Limit:65536KB
    Total submit users: 23, Accepted users: 23
    Problem 12598 : No special judgement
    Problem description
    Casting around for problems leads us to combine modular arithmetic with different integer bases, particularly the problem of computing values modulo b - 1, where b is the base in which the value is represented. For example, 
    782910 mod 9 = 8 
    377777777777777738 mod 7 = 6 
    1234567 mod 6 = 3 
    (Note that 377777777777777738 = 112589990684261910 and 1234567 = 2287510.) 
    Your job is to write a program that reads integer values in various bases and computes the remainder after dividing these values by one less than the input base.



    Input
    The first line of input contains a single integer P, (1 ≤ P ≤ 1000), which is the number of data sets that follow. Each data set should be processed identically and independently. 
    Each data set consists of a single line of input containing three space-separated values. The first is an integer which is the data set number. The second is an integer which is the number, B (2 ≤ B ≤ 10), denoting a numeric base. The third is an unsigned number, D, in base B representation. For this problem, the number of numeric characters in D will be limited to 10,000,000. 


    Output
    For each data set there is a single line of output. It contains the data set number followed by a single space which is then followed by the remainder resulting from dividing D by (B - 1 ). 


    Sample Input
    5
    1 10 7829
    2 7 123456
    3 6 432504023545112
    4 8 37777777777777773
    5 2 10110100010101010101101110001010001010101010101010111
    
    
    Sample Output
    1 8
    2 3
    3 1
    4 6
    5 0
    
    Problem Source
    Greater New York Programming Contest 2012
     1 #include <cstdio>
     2 #include <cstring>
     3 #include <cmath>
     4 using namespace std;
     5 char a[10000000+10];
     6 int main(void){
     7 #ifndef ONLINE_JUDGE
     8   freopen("in", "r", stdin);
     9 #endif
    10   int t; scanf("%d", &t);
    11   while (t--){
    12     int s, b; scanf("%d%d%s", &s, &b, a);
    13     int len = strlen(a), po = 1, temp = 0;
    14     for (int i = len-1; i >= 0; --i){
    15       temp += (a[i]-'0') * po; temp %= (b-1);
    16     }
    17     printf("%d %d\n", s, temp);
    18   }
    19 
    20   return 0;
    21 }

    求在某个进制的数字的余数,没卡。

  • 相关阅读:
    wordpress程序打开太慢的解决方案(一步搞定)
    Emeditor代码编辑器常见的正则表达式总结
    网站关键词排名突然消失的原因正在努力侦破
    如何禁止百度对网站进行转码
    【web前端开发】浏览器兼容性处理大全
    导航悬浮于顶部代码学习
    用最简单的代码写出banner图轮播效果
    这段时间大量网站被k的原因分析
    Python的lambda学习
    随机数生成验证码
  • 原文地址:https://www.cnblogs.com/liuxueyang/p/2952784.html
Copyright © 2011-2022 走看看