鱼C论坛

 找回密码
 立即注册
查看: 4190|回复: 6

a*b/c 数字很大,不用大数法

[复制链接]
发表于 2013-8-1 00:12:57 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
Description:

       题目非常的简单,输入三正整数ABC,输出(A*B)%C的值。不过这样一句scanf和一句printf就能解决的问题肯定会让这么聪明的你感觉很郁闷的,所在这里加一点点难度,测试数据里的A,B,C的值会稍大一点点,不过最大不会超过2^63。
      或许,你会想用大数做,不过大数的乘和模不是很好写,那有没有其它方法呢。我想,聪明的你很快就想到的 :)
      


Input:

输入多组测试数据,每组一行三个正整数,A,B,C。0 < A , B , C < 263 。



Output:

每个测试数据一行,(A*B)%C的值。



Sample Input:

1 2 10 12 14 100 15 3 21



Sample Output:

2 68 3

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2013-8-1 00:36:10 | 显示全部楼层
标题写错了:sweat:       是   a * b % c
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2013-8-1 00:38:31 | 显示全部楼层
Input:

输入多组测试数据,每组一行三个正整数,A,B,C。0 < A , B , C < 2 的 63 次 方。
:sweat::sweat::sweat::sweat::sweat::sweat::sweat::sweat:


想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-8-1 01:21:03 | 显示全部楼层

  1. #include<stdio.h>

  2. int main()
  3. {
  4.         int a,b,c;

  5.         while ( scanf("%d%d%d",&a,&b,&c)!=EOF && a!=0 && b!=0 && c!=0 )
  6.         {
  7.                 int k=1;
  8.                 while (b>0)
  9.                 {
  10.                         if(b&1!=0)     // 作用1:当 b为奇数,则先单独乘一个a
  11.                                               // 作用:当 b=1时,即 已经乘了 b=b/2=1后,将值赋给k
  12.                                 k=(k*a)%c;   
  13.                         a=(a*a)%c;   
  14.                         b>>=1;         // a1=a%c                                               1=2^0   
  15.                                              // a2=((a%c)*(a%c))%c                           2=2^1
  16.                                              // a3=((a%c*a%c)%c*(a%c*a%c)%c)      4=2^2
  17.                                              // 由此,可知 b=b/2 ,每次的 a 的个数为上一次的 2倍
  18.                 }
  19.                 printf("%d\n",k);
  20.         }
  21.         return 0;
  22. }
复制代码

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2013-8-4 12:35:26 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-8-15 08:28:54 | 显示全部楼层
学习了,支持啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-8-21 20:51:10 | 显示全部楼层
  1. #include <stdio.h>

  2. int main()
  3. {
  4.         long a,b,c;
  5.         while(scanf("%d%d%d",&a,&b,&c) != EOF)
  6.         {
  7.                 printf("%d\n",((a%c)*(b%c))%c);
  8.         }

  9.         return 0;
  10. }
复制代码
秒杀
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-18 13:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表