题解 | #宝石手串#

宝石手串

https://www.nowcoder.com/practice/9648c918da794be28575dd121efa1c50

断环成链,只有全部宝石都不相同时候无法断裂,否则记录当前宝石出现位置,再次遇到相同宝石时候更新位置比记录答案即可,注意两个宝石之间的宝石数量是(j-i-1)

#include <bits/stdc++.h>
#define ls p<<1
#define print pt
#define fi first
#define rs p<<1|1
#define se second
#define ins insert
#define getchar nc
#define pb push_back
#define lread rd<ll>
#define read rd<int>
#define mk make_pair
#define pf push_front
#define lowb(x) lower_bound(x)
#define uppb(x) upper_bound(x)
#define all(a) a.begin(),a.end()
#define lwb(a,b,c) lower_bound(a,b,c)
#define upb(a,b,c) upper_bound(a,b,c)
#define mset(x,a) memset(x,a,sizeof(x))
#define rep(i,l,r) for(int i=(l);i<=(r);i++)
#define per(i,l,r) for(int i=(l);i>=(r);i--)
using namespace std;
using ll = long long;
using i128 = __int128;
using ld = long double;
using pii = pair<int,int>;
using ull = unsigned long long;
using pll = pair<long long,long long>;
const int base = 1331;
const int N = 1e6 + 7;
const int M = 1e4 + 7;
const int mod = 1e9 + 7;
const double eps = 1e-6;
const int inf = 0x3f3f3f3f;
const long long linf = 0x3f3f3f3f3f3f3f3f;
int dir[4][2]={1,0,0,1,-1,0,0,-1};
int dira[8][2]={{-1,0},{1,0},{0,-1},{0,1},{-1,-1},{-1,1},{1,-1},{1,1}};

//Overloading ostream
template <typename A, typename B> ostream &operator<<(ostream &os, const pair<A, B> &p) { return os << '(' << p.first << ", " << p.second << ')'; }
template<typename C, typename D = typename enable_if<!is_same<C, string>::value, typename C::value_type>::type> ostream &operator<<(ostream &os, const C &v) { os << '{'; string sep; for (const D &x : v) os << sep << x, sep = ", "; return os << '}'; }
template<class Tuple, std::size_t N> struct TuplePrinter { static void print(std::ostream& os, const Tuple& t) { TuplePrinter<Tuple, N - 1>::print(os, t); os << ", " << std::get<N - 1>(t); } };
template<class Tuple> struct TuplePrinter<Tuple, 1> { static void print(std::ostream& os, const Tuple& t) { os << std::get<0>(t); } };
template<typename... Args> std::ostream& operator<<(std::ostream& os, const std::tuple<Args...>& t) { os << "("; TuplePrinter<decltype(t), sizeof...(Args)>::print(os, t); os << ")"; return os; }
template <typename T> ostream &operator<<(ostream &os, const set<T> &s) { os << '{'; string sep; for (const auto &x : s) os << sep << x, sep = ", "; return os << '}'; }
template <typename T> ostream &operator<<(ostream &os, const multiset<T> &s) { os << '{'; string sep; for (const auto &x : s) os << sep << x, sep = ", "; return os << '}'; }
template <typename K, typename V> ostream &operator<<(ostream &os, const map<K, V> &m) { os << '{'; string sep; for (const auto &p : m) os << sep << p.first << ": " << p.second, sep = ", "; return os << '}'; }
template <typename K, typename V> ostream &operator<<(ostream &os, const multimap<K, V> &m) { os << '{'; string sep; for (const auto &p : m) os << sep << p.first << ": " << p.second, sep = ", "; return os << '}'; }
template <typename T> ostream &operator<<(ostream &os, const unordered_set<T> &s) { os << '{'; string sep; for (const auto &x : s) os << sep << x, sep = ", "; return os << '}'; }
template <typename T> ostream &operator<<(ostream &os, const unordered_multiset<T> &s) { os << '{'; string sep; for (const auto &x : s) os << sep << x, sep = ", "; return os << '}'; }
template <typename K, typename V> ostream &operator<<(ostream &os, const unordered_map<K, V> &m) { os << '{'; string sep; for (const auto &p : m) os << sep << p.first << ": " << p.second, sep = ", "; return os << '}'; }
template <typename K, typename V> ostream &operator<<(ostream &os, const unordered_multimap<K, V> &m) { os << '{'; string sep; for (const auto &p : m) os << sep << p.first << ": " << p.second, sep = ", "; return os << '}'; }
template <typename T> ostream &operator<<(ostream &os, const stack<T> &s) { stack<T> temp = s; os << '['; string sep; while (!temp.empty()) { os << sep << temp.top(); temp.pop(); sep = ", "; } return os << ']'; }
template <typename T> ostream &operator<<(ostream &os, const queue<T> &q) { queue<T> temp = q; os << '['; string sep; while (!temp.empty()) { os << sep << temp.front(); temp.pop(); sep = ", "; } return os << ']'; }
template <typename T> ostream &operator<<(ostream &os, const priority_queue<T> &pq) { priority_queue<T> temp = pq; os << '['; string sep; while (!temp.empty()) { os << sep << temp.top(); temp.pop(); sep = ", "; } return os << ']'; }
template <typename T, size_t N> ostream &operator<<(ostream &os, const array<T, N> &a) { os << '{'; string sep; for (const auto &x : a) os << sep << x, sep = ", "; return os << '}'; }
template <typename T> ostream &operator<<(ostream &os, const deque<T> &dq) { os << '{'; string sep; for (const auto &x : dq) os << sep << x, sep = ", "; return os << '}'; }

//Debug
void dbg_out() { cerr << endl; }
template <typename Head, typename... Tail> void dbg_out(Head H, Tail... T) { cerr << ' ' << H; dbg_out(T...); }
#ifndef ONLINE_JUDGE
#define dbg(...) cerr << "(" << #__VA_ARGS__ << "):", dbg_out(__VA_ARGS__)
#else
#define dbg(...)
#endif

//Fast read
inline char nc() { static char buf[100000], *p1 = buf, *p2 = buf; return p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 100000, stdin), p1 == p2) ? EOF : *p1++; }
template<class T> T rd() { int f = 0, c; T x = 0; while (!isdigit(c = nc())) f |= c == '-'; x = (c ^ 48); while (isdigit(c = nc())) x = x * 10 + (c ^ 48); if (f) x = -x; return x; }
template<class T> void pt(T x, int c = -1) { if (x < 0) putchar('-'), x = -x; if (x > 9) pt(x / 10); putchar(x % 10 + 48); if (c != -1) putchar(c); }

ll n,m;
string s;
void solve(){ 
  cin>>n>>s;s+=s;s=" "+s;
  vector<int> vis(30,0);
  rep(i,1,n){
    vis[s[i]-'a'+1]++;
  }
  bool ok = true;
  for(auto c:vis){
    if(c>1)ok=false;
  }
  if(ok){
    cout<<-1<<"\n";return;
  }
  vector<int> mp(30,0);
  int ans = inf;
  n<<=1;
  rep(i,1,n){
    if(!mp[s[i]-'a'+1])mp[s[i]-'a'+1]=i;
    else {ans=min(ans,i-mp[s[i]-'a'+1]-1);mp[s[i]-'a'+1]=i;}
  }
  if(ans==inf)cout<<-1<<"\n";
  else cout<<ans<<"\n";
  return;
}
int main(){
  ios::sync_with_stdio(0); cin.tie(0); cout.tie(0);
  // cout << fixed << setprecision(3);
  // cout << right << left << setw(3);
  int _; cin>>_; while (_--)
  solve();
  return 0;
}
全部评论

相关推荐

从输入URL到页面加载发生了什么:总体来说分为以下几个过程:&nbsp;1.DNS解析&nbsp;2.TCP连接&nbsp;3.发送HTTP请求&nbsp;4.服务器处理请求并返回HTTP报文&nbsp;5.浏览器解析渲染页面&nbsp;6.连接结束。简述了一下各个过程的输入输出作用:以下是对从输入&nbsp;URL&nbsp;到页面加载各过程的输入、输出或作用的一句话描述:DNS&nbsp;解析:&nbsp;输入:用户在浏览器地址栏输入的域名(如&nbsp;www.example.com)。输出:对应的&nbsp;IP&nbsp;地址(如&nbsp;192.168.1.1)。作用:将易于记忆的域名转换为计算机能够识别和用于网络通信的&nbsp;IP&nbsp;地址,以便浏览器与目标服务器建立连接。TCP&nbsp;连接:&nbsp;输入:浏览器获得的服务器...
明天不下雨了:参考一下我的说法: 关键要讲出输入网址后涉及的每一个网络协议的工作原理和作用: 涉及到的网络协议: HTTP/HTTPS协议->DNS协议->TCP协议->IP协议->ARP协议 面试参考回答: 第一次访问(本地没有缓存时): 一般我们在浏览器地址栏输入的是一个域名。 浏览器会先解析 URL、解析出域名、资源路径、端口等信息、然后构造 HTTP 请求报文。浏览器新开一个网络线程发起HTTP请求(应用层) 接着进行域名解析、将域名解析为 IP 地址 浏览器会先检查本地缓存(包括浏览器 DNS 缓存、操作系统缓存等)是否已解析过该域名 如果没有、则向本地 DNS 服务器请求解析; 本地服务器查不到会向更上层的 DNS 服务器(根域名服务器->顶级域名服务器->权威域名服务器询问)递归查询 最终返回该域名对应的 IP 地址。(应用层DNS协议)DNS 协议的作用: 将域名转换为 IP 地址。 由于 HTTP 是基于 TCP 传输的、所以在发送 HTTP 请求前、需要进行三次握手、在客户端发送第一次握手的时候、( 浏览器向服务器发送一个SYN(同步)报文、其中包含客户端的初始序列号。TCP头部设置SYN标志位、并指定客户端端口 同时填上目标端口和源端口的信息。源端口是浏览器随机生成的、目标端口要看是 HTTP 还是 HTTPS、如果是 HTTP 默认目标端口是 80、如果是 HTTPS 默认是 443。(传输层) 然后到网络层:涉及到(IP协议) 会将TCP报文封装成IP数据包、添加IP头部,包含源IP地址(浏览器)和目标IP地址(服务器)。IP 协议的作用: 提供无连接的、不可靠的数据包传输服务。 然后到数据链路层、会通过 ARP 协议、获取目标的路由器的 MAC 地址、然后会加上 MAC 头、填上目标 MAC 地址和源 MAC 地址。 然后到物理层之后、直接把数据包、转发给路由器、路由器再通过下一跳、最终找到目标服务器、然后目标服务器收到客户的 SYN 报文后,会响应第二次握手。 当双方都完成三次握手后、如果是 HTTP 协议、客户端就会将 HTTP 请求就会发送给目标服务器。如果是 HTTPS 协议、客户端还要和服务端进行 TLS 四次握手之后、客户端才会将 HTTP 报文发送给目标服务器。 目标服务器收到 HTTP 请求消息后、就返回 HTTP 响应消息、浏览器会对响应消息进行解析渲染、呈现给用户
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务