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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

YBTOJ 特殊数列(哈希表)

發布時間:2023/12/3 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 YBTOJ 特殊数列(哈希表) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 題目描述
  • 解析
  • 代碼

題目描述

解析

應該是哈希表板子題了
選一個1e6左右的質數進行處理即可
其實本質就是鏈前
沒啥特別新鮮的
為什么要寫呢?
因為這個東西很早之前看的時候完全沒有看懂。。。

代碼

#include<bits/stdc++.h> using namespace std; #define ll long long typedef unsigned long long ull; const int N = 3e6+100; const ll mod=1e6+3; ll a,b,c; int fi[N],cnt=-1; ll num[N],tot=0; struct node{int to,nxt; }p[N]; void addline(int x,int y){p[++cnt]=(node){y,fi[x]};fi[x]=cnt; } bool find(ll x){int o=x%mod;for(int i=fi[o];~i;i=p[i].nxt){int to=p[i].to;if(num[to]==x) return true;}return false; } void put(ll x){int o=x%mod;num[++tot]=x;addline(o,tot); } int main(){memset(fi,-1,sizeof(fi));scanf("%lld%lld%lld",&a,&b,&c);ll now=1;put(now);for(int i=1;i<=2e6;i++){now=(a*now+now%b)%c;if(find(now)){printf("%d",i);return 0;}put(now);}printf("-1");return 0; } /* 3 1 2 3 4 5 6 7 8 9 5 6 7 8 9 1 2 3 4 */

總結

以上是生活随笔為你收集整理的YBTOJ 特殊数列(哈希表)的全部內容,希望文章能夠幫你解決所遇到的問題。

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