zoukankan      html  css  js  c++  java
  • 10162

    UVA 10162 - Last Digit

    题目链接

    题意:求S=(11+22+...NN)%10

    思路:打出0-9的每一个周期,发现周期为1或2或4、所以S是以20一个周期,打出表后发现20为4。所以相应的40为8。60为2,80为6。100为0,100为1个周期,且为0,所以先把数字mod上100,然后在mod 20求出相应位置。

    代码:

    #include <stdio.h>
    #include <string.h>
    
    const int Z2[10] = {0, 4, 8, 2 ,6};
    int T[10][10], tn[10];
    int Z[25];
    char str[105];
    
    int solve(int mod) {
        int len = strlen(str);
        int yu = 0;
        for (int i = 0; i < len ;i++) {
    	yu = (yu * 10 + str[i] - '0') % mod;
        }
        return yu;
    }
    
    int main() {
        for (int i = 0; i < 10; i++) {
    	int tmp = i;
    	T[i][tn[i]++] = i;
    	tmp = tmp * i % 10;
    	while (tmp != i) {
    	    T[i][tn[i]++] = tmp;
    	    tmp = tmp * i % 10;
    	}
        }
        for (int i = 1; i <= 20; i++) {
    	int tmp = i % tn[i % 10] - 1;
    	if (tmp < 0) tmp += tn[i % 10];
    	Z[i] = (Z[i - 1] + T[i % 10][tmp]) % 10;
        
        }
        /*for (int i = 1; i <= 20; i++)
    	printf("%d
    ", Z[i]);
        for (int i = 0; i < 10; i++) {
    	printf("%d: zhouqi %d:
    ", i, tn[i]);
    	for (int j = 0; j < tn[i]; j++)
    	    printf("%d ", T[i][j]);
    	printf("
    ");
        }*/
        while (~scanf("%s", str) && str[0] != '0') {
    	int yu = solve(100);
    	int ans = (Z[yu % 20] + Z2[yu / 20]) % 10;
    	printf("%d
    ", ans);
        }
        return 0;
    }


查看全文
  • 相关阅读:
    湖南省第6届程序大赛第6题 Biggest Number
    湖南省第6届程序大赛第5题 内部收益率
    湖南省第6届程序大赛第4题 台球碰撞
    湖南省第6届程序大赛第3题 数字整除
    湖南省第6届程序大赛第二题 弟弟的作业
    湖南省第6届程序设计大赛第一题 汽水瓶
    Nginx 负载均衡配置
    Nginx 反向代理流程
    Nginx 对客户端请求的特殊处理
    Nginx文件操作的优化
  • 原文地址:https://www.cnblogs.com/ldxsuanfa/p/10630599.html
  • Copyright © 2011-2022 走看看