日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

[ZJOI 2010]count 数字计数

發布時間:2025/3/21 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [ZJOI 2010]count 数字计数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Description

題庫鏈接

問你 \([l,r]\) 區間內所有整數中各個數碼出現了多少次。

\(1\leq a\leq b\leq 10^{12}\)

Solution

數位 \(DP\)

定義一個函數 \(cal(i)\) 為求 \([1,i)\) 中所有整數各個數碼的和。顯然答案就是 \(cal(r+1)-cal(l)\)

考慮如何求 \(cal(x)\)

先考慮數的位數小于 \(x\) 的情況。假設 \(x\) 的總位數為 \(tot\) 。我們可以從 \(1\sim tol-1\) 來枚舉最高位。對于每次枚舉的最高位 \(i\) ,顯然最高位上的每個數都會計算 \(10^{i-1}\) 次, \(0\) 除外。再考慮以其為最高位開頭。之后的所有數碼產生的新貢獻為 \(9(i-1)\cdot 10^{i-2}\) 其中 \(9\) 表示最高位有 \([1,9]\)\(9\) 個數; \(i-1\) 表示之后共有 \(i-1\) 位。 \(10^{i-2}\) 指的是每一位會產生貢獻(推推式子可以證明后面的每一位的數碼出現頻率是相同的)。

最高位等于 \(tot\) 的情況和上面是類似的,假設 \(x_i\)\(x\) 的第 \(i\) 位上的數字。顯然對于小于 \(x_i\) 的所有數碼(包括除最高位外的 \(0\) ),都會計算 \(10^{i-1}\) 次。而 \(x_i\) 只會計算 \(last\) 次,其中 \(last\)\(i\) 位之后的數字;之后的所有數碼產生的新貢獻和上面類似,詳可見代碼。

Code

//It is made by Awson on 2018.2.28 #include <bits/stdc++.h> #define LL long long #define dob complex<double> #define Abs(a) ((a) < 0 ? (-(a)) : (a)) #define Max(a, b) ((a) > (b) ? (a) : (b)) #define Min(a, b) ((a) < (b) ? (a) : (b)) #define Swap(a, b) ((a) ^= (b), (b) ^= (a), (a) ^= (b)) #define writeln(x) (write(x), putchar('\n')) #define lowbit(x) ((x)&(-(x))) using namespace std; void read(LL &x) {char ch; bool flag = 0;for (ch = getchar(); !isdigit(ch) && ((flag |= (ch == '-')) || 1); ch = getchar());for (x = 0; isdigit(ch); x = (x<<1)+(x<<3)+ch-48, ch = getchar());x *= 1-2*flag; } void print(LL x) {if (x > 9) print(x/10); putchar(x%10+48); } void write(LL x) {if (x < 0) putchar('-'); print(Abs(x)); }LL x, y, cnt[15];void cal(LL x) {LL a[20], tot = 0, mi = 1, last = 0; while (x) a[++tot] = x%10, x /= 10;for (int i = 1; i < tot; i++) {for (int d = 1; d < 10; d++) cnt[d] += mi;for (int d = 0; d < 10; d++) cnt[d] += mi*9/10*(i-1); mi *= 10;}mi = 1;for (int i = 1; i <= tot; i++) {cnt[a[i]] += last; int begin = (i == tot);for (int d = begin; d < a[i]; d++) cnt[d] += mi;if (a[i]) for (int d = 0; d < 10; d++) cnt[d] += mi*(a[i]-begin)/10*(i-1);last += mi*a[i], mi *= 10;} } void work() {read(x), read(y);cal(x); for (int i = 0; i < 10; i++) cnt[i] = -cnt[i];cal(y+1); for (int i = 0; i < 9; i++) write(cnt[i]), putchar(' '); writeln(cnt[9]); } int main() {work(); return 0; }

轉載于:https://www.cnblogs.com/NaVi-Awson/p/8483411.html

總結

以上是生活随笔為你收集整理的[ZJOI 2010]count 数字计数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 午夜电影在线播放 | 日本草草影院 | 福利视频亚洲 | 欧美日韩久久婷婷 | 成人精品视频在线观看 | 午夜精品偷拍 | 亚洲国产成人一区二区精品区 | 日韩大片免费在线观看 | 国产精品乱码久久久久久 | www.爱色av.com| 福利在线影院 | 日本最黄网站 | 日韩一级在线观看视频 | 精品人妻在线播放 | 国产精品无码一区二区三区 | 精品无码m3u8在线观看 | 美女扒开尿口让男人捅爽 | 欧美黄色大片视频 | 久久久综合av | 老头老夫妇自拍性tv | 国产激情无套内精对白视频 | 国产一区二区三区四区五区在线 | 轻轻色在线观看 | 97av在线播放 | 国产精品久久免费 | 国产女主播一区 | 欧美性生活xxx | 久久久免费高清视频 | 免费看女生裸体视频 | 日韩av电影一区 | 色噜噜一区二区三区 | 6090伦理| 国产亚洲视频在线观看 | av美国| 亚洲av综合色区无码一区 | 黄色一级片黄色一级片 | 女人十八毛片嫩草av | 三级三级久久三级久久18 | 日韩新片王网 | av软件在线观看 | 一区二区三区精品在线 | 国产欧洲亚洲 | 影音先锋在线国产 | 69久久精品无码一区二区 | 日韩在线精品视频 | 国产免费一区二区三区最新不卡 | 欧美精品黑人 | 精品视频在线免费看 | 国产精品呻吟久久 | 欧美日韩综合在线观看 | 深夜国产视频 | 大肉大捧一进一出好爽 | 美攻壮受大胸奶汁(高h) | 冲田杏梨av | 亚洲小说区图片区都市 | 欧美丝袜视频 | 成人午夜视频免费在线观看 | 看黄色网址 | 国产精品欧美久久久久久 | 一级做a免费 | 人人妻人人澡人人爽欧美一区 | 国产麻豆成人精品av | 久久久久亚洲av无码专区体验 | 免费看欧美黑人毛片 | aaa级片 | 日韩免费一级 | 亚洲成av | 久久综合九色综合欧美狠狠 | 欧美一区二区在线视频 | 中国精品毛片 | 韩国一区二区三区视频 | 永久免费av网站 | 毛片网络 | 日韩h视频 | 欧美激情区 | 亚洲一级特黄 | 国产三级精品三级在线观看 | 在线91av | 久久精品这里只有精品 | 色视频免费看 | 天堂福利视频 | 日韩欧美国产成人精品免费 | 影音先锋在线观看视频 | 四季av日韩精品一区 | 午夜不卡福利视频 | 四虎国产精品永久免费观看视频 | 久久99久久久 | 成人看片黄a免费看视频 | 久操综合| 尤物精品视频在线观看 | 亚洲天堂伊人网 | 爱豆国产剧免费观看大全剧集 | 看看毛片| 爱爱视频免费看 | 九九久久国产视频 | 日本三级一区二区 | 亚洲国产精品suv | 特黄特色大片免费播放器使用方法 | 女同在线视频 |