停课day2
感觉今天好颓啊,我才把昨晚那五道题a了,(但我明明一直在学啊,为啥这么慢,难道是我太笨了?)
闲话少叙,先说做法
问题 A: C Looooops
题目描述
对于C的for(i=A ; i!=B ;i +=C)循环语句,给出A,B,C和k(k表示变量是在k进制下的无符号整数),判断循环次数,不能终止输出"FOREVER".
输入
输出
样例输入
3 3 2 16
3 7 2 16
7 3 2 16
3 4 2 16
0 0 0 0
样例输出
0
2
32766
FOREVER
提示
ll exgcd(ll a,ll b,ll &x,ll &y){
if(b==){
x=;y=;return a;
}
ll ans=exgcd(b,a%b,x,y);
ll t=x;
x=y;
y=t-a/b*y;
return ans;
}
ll cal(ll a,ll b,ll c){
ll x,y;
ll gcd=exgcd(a,b,x,y);
if(c%gcd)return -;
x*=c/gcd;
b/=gcd;
b=abs(b);
ll ans=x%b;
while(ans<=)ans+=b;
return ans;
}
主体代码
第二题是培训的时候的题,数据稍微加强。不说了就。
问题 C: 数论好题
题目描述
给定A,B,求A^B的所有因数的和,再MOD 9901
输入
输出
样例输入
2 3
样例输出
15
提示
#define ll long long
#define mod 9901
ll power(ll a,ll b){
if(b==)return ;
else if(b&)return power(a*a%mod,b>>)*a%mod;
else return power(a*a%mod,b>>)%mod;
}
int p[],cnt,f[];
void getp(ll m){
f[]=;
for(int i=;i<=sqrt(m);i++){
if(!f[i])p[++cnt]=i;
for(int j=i+;i*j<=sqrt(m);j++){
f[i*j]=;
}
}
}
int main(){
ll a,b;
int k=;
cin>>a>>b;
getp(a);ll ans=,pc=;
for(int i=;i<=cnt;i++){
if(a%p[i]==){
while(a%p[i]==){
pc++;a/=p[i];
}
pc*=b;
//pc%=(mod-1);
ans=(ans*(power(p[i],pc+)-)*power(p[i]-,mod-))%mod;
}
pc=;
}
if(a!=){
ans=(ans*(power(a,b+)-)*power(a-,mod-))%mod;
}
问题 E: 数论good
题目描述
输入
输出
样例输入
4 2
样例输出
2048
提示
ll crt(){
ll m=;
ll x,y,d,ans=;
for(int i=;i<=;i++)m*=w[i];
for(int i=;i<=;i++){
d=m/w[i];
exgcd(d,w[i],x,y);
ans=(ans+d*a[i]*x)%m;
//cout<<d<<endl;
}
while(ans<=)ans+=m;
return ans;
}
问题 D: [SDOI2009]SuperGCD
题目描述
Sheng bill有着惊人的心算能力,甚至能用大脑计算出两个巨大的数的GCD(最大公约 数)!因此他经常和别人比赛计算GCD。有一天Sheng bill很嚣张地找到了你,并要求和你比 赛,但是输给Sheng bill岂不是很丢脸!所以你决定写一个程序来教训他。
输入
共两行: 第一行:一个数A。 第二行:一个数B。
输出
一行,表示A和B的最大公约数。
样例输入
12
54
样例输出
6
提示
对于20%的数据,0 < A , B ≤ 10 ^ 18。
对于100%的数据,0 < A , B ≤ 10 ^ 10000。
这道恶心的高精度题恶心了我好久,最后发现读入错了。。。压位的时候要注意第一位要特判。
GCD(A,B)=2GCD(A/2,B/2)
GCD(A,B)=GCD(A/2,B)=GCD(A,B/2)
GCD(A,B)=GCD(A-B,B)
#include<iostream>
#include<cmath>
#include<cstring>
#include<algorithm>
#include<cstdio>
#include<queue>
using namespace std;
//unsigned long long a1[1002],b1[1002],ans=0;int k=1,l=1;long long mod=10000000000;
#define ll long long
#define mod 1000000000ll
ll ans=,k=,l=;
ll a1[],b1[];
bool pd(){
int i;
for(i=;i<=max(l,k);i++){
if(a1[i]!=b1[i])return ;
}
return ;
}
void jian(){
int i=;
while(i<=l||i<=k){
if(a1[i]<b1[i]){
a1[i]+=mod;
a1[i+]--;
}
a1[i]-=b1[i];
i++;
}
}
void diva(){
for(int i=k;i>;i--){
a1[i-]+=(a1[i]%)*mod;
a1[i]/=;
}
a1[]/=; }
void divb(){
for(int i=l;i>;i--){
b1[i-]+=(b1[i]%)*mod;
b1[i]/=;
}
b1[]/=;
}
void gcd(){
if(pd())return ;
while(a1[]%==){diva();}
while(b1[]%==){divb();}
if(pd())return ;
while(a1[k]==)k--;
while(b1[l]==)l--;
int i=max(k,l);
while(a1[i]==b1[i])i--;
if(a1[i]>b1[i])jian();
else {
for(;i>=;i--)swap(a1[i],b1[i]);swap(k,l);jian();}
gcd();
}
int main(){
char a[],b[];
scanf("%s%s",a,b);
int lena=strlen(a);
int lenb=strlen(b);
//memset(a1,0,sizeof(a1));
//memset(b1,0,sizeof(b1));
for(int i=lena-,t=;i>=;i--,t*=){
if((lena-i-)%==&&lena-i-){
k++;t=; }
ll x=a[i]-'';
a1[k]+=x*t;
} for(int i=lenb-,t=;i>=;i--,t*=){
if((lenb-i-)%==&&lenb-i-){
l++;t=; }
ll x=b[i]-'';
b1[l]+=x*t;
}
//for(int i=l;i>=1;i--)cout<<b1[i];
while(a1[]%==&&b1[]%==){
diva();
divb();
ans++;
} gcd();
for(int i=;i<=ans;i++){
for(int j=k;j>=;j--){
a1[j]*=;
a1[j+]+=a1[j]/mod;
a1[j]%=mod;
}
if(a1[k+]>)k++;}
while(a1[k]==)k--;
cout<<a1[k];
k--;
for(;k>=;k--)printf("%09d",a1[k]); return ;
}
停课day2的更多相关文章
- tricks - 思维
编辑 目录 tricks 系列 随机的性质 bitmask 建图 最基本的 黑白染色 Kruskal重构树 并查集维护值域 带根号的数三元环 根号分治 调和级数哈希 多属性哈希 时光倒流 时光反复横跳 ...
- 考前停课集训 Day2 非
因为太长了 所以一天一天分开发 Day2 昨天晚上没开黑车 没脱衣服就睡了 可能是我难受了…… 新的一天. 早上好. 我没去晨跑,早上先和团长集合了,没看见rkbudlo来 于是就先吃饭了 去机房的时 ...
- NOIP2017+停课总结
注意 此文章禁止一切含虚伪内容的评论,违者删除评论 其删除解释权归博主所有 Part1 论yyb NOIP 如何炸裂 前言 离NOIP已有三个星期,忘却的救主快要降临了吧,我正有写一篇总结的必要了.. ...
- ZJOI2019一轮停课刷题记录
Preface 菜鸡HL终于狗来了他的省选停课,这次的时间很长,暂定停到一试结束,不过有机会二试的话还是可以搞到4月了 这段时间的学习就变得量大而且杂了,一般以刷薄弱的知识点和补一些新的奇怪技巧为主. ...
- NOIp2018集训test-10-6/test-10-7 (联考五day1/day2)
昨天考完月考,明天初赛,dcoi2017级今天终于开始停课准备noip了,大概没有比本弱校停课更晚的学校了吧.本来就够菜了,怕是要凉透哦. DAY1 T1石头剪刀布 据说爆搜随便做,但是我觉得我的O( ...
- 【从零开始学BPM,Day2】默认表单开发
[课程主题]主题:5天,一起从零开始学习BPM[课程形式]1.为期5天的短任务学习2.每天观看一个视频,视频学习时间自由安排. [第二天课程] Step 1 软件下载:H3 BPM10.0全开放免费下 ...
- NOIp2016 Day1&Day2 解题报告
Day1 T1 toy 本题考查你会不会编程. //toy //by Cydiater //2016.11.19 #include <iostream> #include <cstd ...
- day2
三级菜单: ))))))))))] last_levels.pop() ]]]]]]]]:] information = : ch = msvcrt.getch() ][][: : password= ...
- java day2一个模拟双色球的代码
package day2; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import java.awt ...
随机推荐
- YII2.O学习三 前后台用户数据表分离
之前我们完成了Advanced 模板安装,也完成了安装adminlte 后台模板,这一步是针对前端和后台用户使用不同的数据库表来管理,做到前后台用户分离的效果: 复制一张user数据表并重命名为adm ...
- Hadoop(6)-HDFS的shell操作
1.基本语法 使用 hadoop fs 具体命令 或者 hdfs dfs 具体命令 hadoop命令的shell源码 hdfs命令的shell源码 由此可见,这两个命令最后都是执行的一个jav ...
- Teen Readers【青少年读者】
Teen Readers Teens and younger children are reading a lot less for fun, according to a Common Sense ...
- 9-C++远征之多态篇-学习笔记
C++远征之多态篇 面向对象三大特征:封装,继承,多态 多态: 发出一条命令时,不同的对象接收到同样的命令做出的动作不同 多态篇会学习到的目录: 普通虚函数 & 虚析构函数 纯虚函数:抽象类 ...
- python基础之多线程
概念 进程:进程就是一个程序在一个数据集上的一次动态执行过程 程序:代码 数据集:程序执行过程中需要的资源 进程控制块:完成状态保存的单元 线程:线程是寄托在进程之上,为了提高系统的并发性 线程是进程 ...
- java线程池技术
1.线程池的实现原理?简介: 多线程技术主要解决处理器单元内多个线程执行的问题,它可以显著减少处理器单元的闲置时间,增加处理器单元的吞吐能力.假设一个服务器完成一项任务所需时间为:T1 创建线程时间, ...
- How to enable download EXE files from the Sharepoint website
As we all know,many applications have forbidden to upload and download exe files.Because the e ...
- IDA动态调试SO文件
1. 所需工具 IDA Pro 6.6. 安卓SDK工具 2. 模拟器设置 将ida所在目录的dbgsrv文件夹内的android_server文件push到模拟器中. 设置777属性 启动调试服务器 ...
- Vue学习(二):class与style绑定
<!DOCTYPE html> <html lang="en" xmlns:v-bind="http://www.w3.org/1999/xhtml&q ...
- 孤荷凌寒自学python第六十七天初步了解Python爬虫初识requests模块
孤荷凌寒自学python第六十七天初步了解Python爬虫初识requests模块 (完整学习过程屏幕记录视频地址在文末) 从今天起开始正式学习Python的爬虫. 今天已经初步了解了两个主要的模块: ...