https://vijos.org/p/1447

一开始想了想似乎只想到了与约数个数有关,即约数个数为奇数那么显然是亮的。

竟然没想到完全平方数。。sad。。

在正因子中,只有完全平方数的正因子才是奇数!(包括1和他自己)!!!

在区间[1, n]中,一共有sqrt(n)个完全平方数!(这个多想想就知道了。。。)

然后就是高精度。。。高精度的开方不难写,(但是我在我的高精模板上找到了错误good。。就是不要memset整个数组,要不然果断tle)二分mid然后验证即可。

#include <cstdio>
#include <cstring>
#include <cmath>
#include <string>
#include <iostream>
#include <algorithm>
#include <queue>
using namespace std;
#define rep(i, n) for(int i=0; i<(n); ++i)
#define for1(i,a,n) for(int i=(a);i<=(n);++i)
#define for2(i,a,n) for(int i=(a);i<(n);++i)
#define for3(i,a,n) for(int i=(a);i>=(n);--i)
#define for4(i,a,n) for(int i=(a);i>(n);--i)
#define CC(i,a) memset(i,(a),sizeof(i))
#define read(a) a=getint()
#define print(a) printf("%d", a)
#define dbg(x) cout << (#x) << " = " << (x) << endl
#define printarr2(a, b, c) for1(_, 1, b) { for1(__, 1, c) cout << a[_][__]; cout << endl; }
#define printarr1(a, b) for1(_, 1, b) cout << a[_] << '\t'; cout << endl
inline const int getint() { int r=0, k=1; char c=getchar(); for(; c<'0'||c>'9'; c=getchar()) if(c=='-') k=-1; for(; c>='0'&&c<='9'; c=getchar()) r=r*10+c-'0'; return k*r; }
inline const int max(const int &a, const int &b) { return a>b?a:b; }
inline const int min(const int &a, const int &b) { return a<b?a:b; } const int N=100005;
int f[11][N+5], tp1[N+5], tp2[N+5], tp3[N+5], tp4[N+5], Ten[N+5], One[N+5], Two[N+5];
char s[N+5];
void Plus(int *a, int *b, int *c);
void Print(int *a);
inline void fix1(int *a, int len) { while(len>1 && !a[len]) --len; a[0]=len; }
inline void fix2(int *a, int *b, int *c) { c[N]=(a[N]^b[N])&&(!(c[0]==1 && c[1]==0)); }
inline void upd(int *a) { memset(a, 0, sizeof(int)*(a[0]+1)); a[0]=1; }
inline void Init() { Ten[0]=2; Ten[2]=1; One[0]=One[1]=1; Two[0]=1; Two[1]=2; }
bool cmp(int *a, int *b) {
if(a[N]^b[N]) return a[N];
if(a[N]==1) swap(a, b);
if(a[0]<b[0]) return 1; else if(a[0]>b[0]) return 0;
for3(i, a[0], 1) if(a[i]<b[i]) return 1; else if(a[i]>b[i]) return 0;
return 0;
}
void Minus(int *a, int *b, int *c) {
int i, flag=0;
if(a[N] && b[N]) { b[N]=a[N]=0; Minus(b, a, c); b[N]=a[N]=1; return; }
if(b[N]) { b[N]=0; Plus(a, b, c); b[N]=1; return; }
if(a[N]) { b[N]=1; Plus(a, b, c); b[N]=0; return; }
if(cmp(a, b)) flag=1, swap(a, b);
upd(c);
for(i=1; i<=a[0]; ++i) {
c[i]+=a[i]-b[i];
while(c[i]<0) c[i]+=10, c[i+1]-=1;
}
fix1(c, i); if(flag) c[N]=1;
}
void Plus(int *a, int *b, int *c) {
if(a[N]^b[N]) { if(a[N]) { a[N]=0; Minus(b, a, c); a[N]=1; } else { b[N]=0; Minus(a, b, c); b[N]=1; } return; }
upd(c);
int k=0, len=max(a[0], b[0]), i;
for(i=1; i<=len || k; ++i) {
c[i]=a[i]+b[i]+k;
k=c[i]/10; if(c[i]>=10) c[i]%=10;
}
fix1(c, i); c[N]=a[N];
}
void Multi(int *a, int *b, int *c) {
upd(c);
for1(i, 1, a[0]) for1(j, 1, b[0]) c[i+j-1]+=a[i]*b[j];
int k=0, i, len=a[0]+b[0]-1;
for(i=1; i<=len || k; ++i) {
c[i]+=k;
k=c[i]/10; if(c[i]>=10) c[i]%=10;
}
fix1(c, i); fix2(a, b, c);
}
void Div(int *a, int *b, int *c) {
upd(c); upd(tp1); upd(tp2); upd(tp3);
int i, *t=tp1, *ans=tp2, *k=tp3, flag=b[N]; b[N]=0;
for(i=a[0]; i>=1; --i) {
Multi(k, Ten, t); swap(k, t);
k[1]=a[i];
Multi(ans, Ten, t); swap(ans, t);
while(!cmp(k, b)) {
Plus(ans, One, t); swap(ans, t);
Minus(k, b, t); swap(k, t);
}
}
memcpy(c, ans, sizeof(int)*(ans[0]+1));
b[N]=flag;
fix1(c, a[0]); fix2(a, b, c);
}
void Print(int *a) {
if(a[N]) printf("-");
for3(i, a[0], 1) print(a[i]);
puts("");
}
void stoi(char *x, int *a) {
int len=strlen(s), i=0;
if(x[0]=='-') a[N]=1, ++i; a[0]=len-i;
for(; i<len; ++i) a[len-i]=s[i]-'0';
}
void sqrt(int *a, int *c) {
upd(c);
int *l=f[3], *r=f[4], *m=f[5], *t=f[6];
l[0]=1; r[a[0]+1]=1; r[0]=a[0]+1;
while(cmp(l, r)) {
upd(t); upd(m);
Plus(l, r, t);
Div(t, Two, m);
Multi(m, m, t);
if(!cmp(a, t)) { swap(l, m); Plus(l, One, t); swap(l, t); }
else swap(r, m);
}
Minus(l, One, t); swap(l, t);
memcpy(c, l, sizeof(int)*(N+5));
}
int main() {
Init();
scanf("%s", s); stoi(s, f[1]);
sqrt(f[1], f[2]);
Print(f[2]);
return 0;
}

描述

一个房间里有n盏灯泡,一开始都是熄着的,有1到n个时刻,每个时刻i,我们会将i的倍数的灯泡改变状态(即原本开着的现将它熄灭,原本熄灭的现将它点亮),问最后有多少盏灯泡是亮着的。

格式

输入格式

一个数n

输出格式

m,表示最后有m盏是亮着的

样例1

样例输入1[复制]

5

样例输出1[复制]

2

限制

1s

提示

范围:40%的数据保证,n<=maxlongint
100%的数据保证,n<=10^200

来源

dejiyu@CSC WorkGroup

【vijos】1447 开关灯泡(高精度+特殊的技巧)的更多相关文章

  1. vijos - P1447开关灯泡 (大数模板 + 找规律 + 全然数 + python)

    P1447开关灯泡 Accepted 标签:CSC WorkGroup III[显示标签] 描写叙述 一个房间里有n盏灯泡.一開始都是熄着的,有1到n个时刻.每一个时刻i,我们会将i的倍数的灯泡改变状 ...

  2. vijosP1447 开关灯泡

    vijosP1447 开关灯泡 链接:https://vijos.org/p/1447 [思路] 数学+高精度. 分析题目:题中有言,i时刻将其所有倍数的灯熄灭,由此得知一个数有多少个倍数就会被操作多 ...

  3. vijos-1447 开关灯泡-大整数开方算法

    描述 一个房间里有n盏灯泡,一开始都是熄着的,有1到n个时刻,每个时刻i,我们会将i的倍数的灯泡改变状态(即原本开着的现将它熄灭,原本熄灭的现将它点亮),问最后有多少盏灯泡是亮着的. 提示 范围:40 ...

  4. Linux 学习笔记

    Linux学习笔记 请切换web视图查看,表格比较大,方法:视图>>web板式视图 博客园不能粘贴图片吗 http://wenku.baidu.com/view/bda1c3067fd53 ...

  5. 最大化 AIX 上的 Java 性能,第 3 部分: 更多就是更好

    http://www.ibm.com/developerworks/cn/aix/library/es-Javaperf/es-Javaperf3.html 最大化 AIX 上的 Java 性能,第 ...

  6. 2.计算机组成-数字逻辑电路 门电路与半加器 异或运算半加器 全加器组成 全加器结构 反馈电路 振荡器 存储 D T 触发器 循环移位 计数器 寄存器 传输门电路 译码器 晶体管 sram rom 微处理 计算机

    现代计算机的各个部件到底是如何通过逻辑电路构成的呢   半加器 我们说过了门电路 看似简单的三种门电路却是组成了整个逻辑电路的根基 真值表--其实就是根据输入输出状态枚举罗列出来的所有可能 比如有一台 ...

  7. 【高精度】Vijos P1010 清帝之惑之乾隆

    题目链接: https://vijos.org/p/1010 题目大意: 多组数据,求R的n次幂(R为不超过9999.9的小数 n<=200)R保证占6位 不输出前导0和后缀0,整数就只输出整数 ...

  8. 【二分】【高精度】Vijos P1472 教主的集合序列

    题目链接: https://vijos.org/p/1472 题目大意: S1={1,2,3…n}.当i>1时,Si为集合Si-1中任意两个不相同数之和的集合. 将每个集合中所有元素取出,集合S ...

  9. Vijos 1040 高精度乘法

    描述 高精度乘法 输入:两行,每行表示一个非负整数(不超过10000位) 输出:两数的乘积. 样例1 样例输入1 99 101 样例输出1 9999 题解 这道题和之前的Vijos 1010 清帝之惑 ...

随机推荐

  1. Discuz常见小问题2-如何清空,删除,清除全部DIY的数据

    如果所有diy都不想要了,手动清空_common_block._common_diy_data与_common_template_block表,然后删除\data\diy\下的所有子文件夹,保证你以前 ...

  2. 倍福TwinCAT(贝福Beckhoff)常见问题(FAQ)-点击激活配置进入到运行模式直接死机或蓝屏怎么办

    下载我提供的TCRtime.sys文件,替换掉TwinCAT/Driver目录下的原有文件(原有文件要小一点,这个是159KB的) 如果你同时也安装了TwinCAT3,请不要替换这个,他是398KB的 ...

  3. FFMpeg框架代码阅读

    http://blog.csdn.net/wstarx/article/details/1572393 FFMPEG源码分析(二) http://www.cnblogs.com/qingquan/ar ...

  4. Struts2-Spring和Hibernate整合

    Struts作为MVC 2的Web框架,自推出以来不断受到开发者的追捧,得到广泛的应用.作为最成功的Web框架,Struts自然拥有众多的优点:MVC 2模型的使用.功能齐全的标志库(Tag Libr ...

  5. 算法笔记_095:蓝桥杯练习 拿糖果(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 妈妈给小B买了N块糖!但是她不允许小B直接吃掉. 假设当前有M块糖,小B每次可以拿P块糖,其中P是M的一个不大于根号下M的质因数.这时,妈 ...

  6. ZK框架笔记4、通用组件、页面、桌面

    组件(component)是一种用户接口(UI)对象,如一个标签.按钮.树.         页面(page)是一个组件的集合.         桌面(desktop)是一个包含相同URL请求的页面. ...

  7. JDBC操作,执行数据库更新操作

    目标: 使用Connection对象取得Statement实例 使用Statement进行数据增删改. Statement接口 要对数据库操作,要使用Statement完成.此接口可以使用Connec ...

  8. Linux 目录和文件操作

    Linux常用命令--目录和文件操作 [目录]删除.复制.移动 : 1.删除文件夹用:rmdir 文件夹名 但是rmdir不能删除非空的文件夹,那如何删除非空文件夹呢: 2.通常情况下,删除文件用:r ...

  9. C语言初级链表(之有头节点的单向链表)

    #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <stdlib.h> typedef struct No ...

  10. [获取行数]php读取大文件提供性能的方法,PHP的stream_get_line函数读取大文件获取文件的行数的方...

    背景: 下面是获取文件的行数的方法: 一个文件如果知道有几行的话,就可以控制获取一定的行数的数据,然后放入数据库.这样不管的读取大文件的性能,还是写入数据库的性能,都能得到很大的提高了. 下面是获取文 ...