Submission #74940832
Source Code Expand
#![allow(dead_code)]
#![allow(unused_imports)]
use std::collections::{BTreeMap, BinaryHeap, HashMap, HashSet, VecDeque};
use std::io::stdin;
#[derive(Default)]
struct Scanner {
buffer: Vec<String>,
}
impl Scanner {
fn next<T: std::str::FromStr>(&mut self) -> T {
loop {
if let Some(token) = self.buffer.pop() {
return token.parse().ok().expect("Failed parse");
}
let mut input = String::new();
stdin().read_line(&mut input).expect("Failed read");
self.buffer = input.split_whitespace().rev().map(String::from).collect();
}
}
}
fn main() {
let mut scanner = Scanner::default();
let n = scanner.next::<usize>();
let l = scanner.next::<u64>();
// Read as (value, 1-based index) pairs
let mut vals: Vec<(u64, usize)> = (0..n).map(|i| (scanner.next::<u64>(), i + 1)).collect();
// Sort by value ascending, tie-break by index ascending
vals.sort_by(|a, b| a.0.cmp(&b.0).then(a.1.cmp(&b.1)));
// Binary search: find the last position where value <= l
// partition_point gives first index where value > l
let index = vals.partition_point(|&(v, _)| v <= l);
if index == 0 {
// No member with value <= l exists
println!("-1");
return;
}
// index-1 is the last element with value <= l
// Among all elements with that maximum value, we want smallest index.
// Because we sorted by (value asc, index asc), the first occurrence
// of the maximum value has the smallest index — but partition_point
// lands us at the END of the max-value group, so we scan back.
let best_val = vals[index - 1].0;
// Find the first element in the group with value == best_val
let group_start = vals.partition_point(|&(v, _)| v < best_val);
println!("{}", vals[group_start].1);
}
Submission Info
| Submission Time | |
|---|---|
| Task | A - Optimal Practice Partner |
| User | anassB |
| Language | Rust (rustc 1.89.0) |
| Score | 233 |
| Code Size | 1922 Byte |
| Status | AC |
| Exec Time | 25 ms |
| Memory | 16056 KiB |
Judge Result
| Set Name | Sample | All | ||||
|---|---|---|---|---|---|---|
| Score / Max Score | 0 / 0 | 233 / 233 | ||||
| Status |
|
|
| Set Name | Test Cases |
|---|---|
| Sample | sample01.txt, sample02.txt, sample03.txt, sample04.txt, sample05.txt |
| All | sample01.txt, sample02.txt, sample03.txt, sample04.txt, sample05.txt, in01.txt, in02.txt, in03.txt, in04.txt, in05.txt, in06.txt, in07.txt, in08.txt, in09.txt, in10.txt, in11.txt, in12.txt, in13.txt, in14.txt, in15.txt, in16.txt, in17.txt, in18.txt, in19.txt, in20.txt, in21.txt, in22.txt, in23.txt, in24.txt, in25.txt, in26.txt, in27.txt, in28.txt, in29.txt, in30.txt, in31.txt, in32.txt, in33.txt, in34.txt, in35.txt, in36.txt, in37.txt, in38.txt, in39.txt, in40.txt, in41.txt, in42.txt, in43.txt, in44.txt, in45.txt, in46.txt, in47.txt, in48.txt, in49.txt, in50.txt, in51.txt, in52.txt, in53.txt, in54.txt, in55.txt, in56.txt, in57.txt, in58.txt, in59.txt, in60.txt, in61.txt, in62.txt, in63.txt, in64.txt, in65.txt, in66.txt, in67.txt, in68.txt, in69.txt, in70.txt, in71.txt, in72.txt, in73.txt |
| Case Name | Status | Exec Time | Memory |
|---|---|---|---|
| in01.txt | AC | 1 ms | 1828 KiB |
| in02.txt | AC | 1 ms | 1840 KiB |
| in03.txt | AC | 1 ms | 1980 KiB |
| in04.txt | AC | 1 ms | 2000 KiB |
| in05.txt | AC | 1 ms | 1932 KiB |
| in06.txt | AC | 1 ms | 1856 KiB |
| in07.txt | AC | 1 ms | 2028 KiB |
| in08.txt | AC | 1 ms | 1892 KiB |
| in09.txt | AC | 1 ms | 1892 KiB |
| in10.txt | AC | 25 ms | 15956 KiB |
| in11.txt | AC | 23 ms | 15928 KiB |
| in12.txt | AC | 21 ms | 15920 KiB |
| in13.txt | AC | 23 ms | 15964 KiB |
| in14.txt | AC | 12 ms | 15880 KiB |
| in15.txt | AC | 22 ms | 15936 KiB |
| in16.txt | AC | 1 ms | 1876 KiB |
| in17.txt | AC | 1 ms | 1928 KiB |
| in18.txt | AC | 24 ms | 15976 KiB |
| in19.txt | AC | 15 ms | 16028 KiB |
| in20.txt | AC | 24 ms | 16024 KiB |
| in21.txt | AC | 15 ms | 16000 KiB |
| in22.txt | AC | 15 ms | 15968 KiB |
| in23.txt | AC | 14 ms | 15876 KiB |
| in24.txt | AC | 15 ms | 16056 KiB |
| in25.txt | AC | 19 ms | 15916 KiB |
| in26.txt | AC | 21 ms | 15980 KiB |
| in27.txt | AC | 23 ms | 15972 KiB |
| in28.txt | AC | 1 ms | 1988 KiB |
| in29.txt | AC | 1 ms | 1956 KiB |
| in30.txt | AC | 1 ms | 1828 KiB |
| in31.txt | AC | 1 ms | 2108 KiB |
| in32.txt | AC | 1 ms | 2052 KiB |
| in33.txt | AC | 24 ms | 15928 KiB |
| in34.txt | AC | 1 ms | 1884 KiB |
| in35.txt | AC | 1 ms | 2084 KiB |
| in36.txt | AC | 1 ms | 1992 KiB |
| in37.txt | AC | 1 ms | 1980 KiB |
| in38.txt | AC | 1 ms | 1928 KiB |
| in39.txt | AC | 1 ms | 1884 KiB |
| in40.txt | AC | 1 ms | 1920 KiB |
| in41.txt | AC | 24 ms | 15988 KiB |
| in42.txt | AC | 1 ms | 1952 KiB |
| in43.txt | AC | 1 ms | 1972 KiB |
| in44.txt | AC | 13 ms | 15920 KiB |
| in45.txt | AC | 24 ms | 16016 KiB |
| in46.txt | AC | 25 ms | 15952 KiB |
| in47.txt | AC | 23 ms | 16052 KiB |
| in48.txt | AC | 24 ms | 15904 KiB |
| in49.txt | AC | 25 ms | 15932 KiB |
| in50.txt | AC | 25 ms | 15948 KiB |
| in51.txt | AC | 1 ms | 2044 KiB |
| in52.txt | AC | 23 ms | 16004 KiB |
| in53.txt | AC | 23 ms | 15932 KiB |
| in54.txt | AC | 23 ms | 15924 KiB |
| in55.txt | AC | 1 ms | 1908 KiB |
| in56.txt | AC | 1 ms | 1948 KiB |
| in57.txt | AC | 1 ms | 1936 KiB |
| in58.txt | AC | 1 ms | 1868 KiB |
| in59.txt | AC | 1 ms | 1976 KiB |
| in60.txt | AC | 1 ms | 1848 KiB |
| in61.txt | AC | 1 ms | 1928 KiB |
| in62.txt | AC | 1 ms | 1892 KiB |
| in63.txt | AC | 1 ms | 1900 KiB |
| in64.txt | AC | 1 ms | 1940 KiB |
| in65.txt | AC | 1 ms | 2032 KiB |
| in66.txt | AC | 1 ms | 1896 KiB |
| in67.txt | AC | 1 ms | 1884 KiB |
| in68.txt | AC | 1 ms | 1952 KiB |
| in69.txt | AC | 1 ms | 1924 KiB |
| in70.txt | AC | 1 ms | 1928 KiB |
| in71.txt | AC | 1 ms | 1976 KiB |
| in72.txt | AC | 1 ms | 1992 KiB |
| in73.txt | AC | 1 ms | 1908 KiB |
| sample01.txt | AC | 1 ms | 1956 KiB |
| sample02.txt | AC | 1 ms | 2028 KiB |
| sample03.txt | AC | 1 ms | 1924 KiB |
| sample04.txt | AC | 1 ms | 1840 KiB |
| sample05.txt | AC | 1 ms | 2000 KiB |