QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#166918#6525. New Housesucup-team134#AC ✓130ms5148kbC++143.8kb2023-09-06 20:53:122023-09-06 20:53:13

Judging History

你现在查看的是最新测评结果

  • [2023-09-06 20:53:13]
  • 评测
  • 测评结果:AC
  • 用时:130ms
  • 内存:5148kb
  • [2023-09-06 20:53:12]
  • 提交

answer

#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
#include <ext/rope>

#define ll long long
#define pb push_back
#define f first
#define s second
#define sz(x) (int)(x).size()
#define all(x) x.begin(), x.end()
#define rall(x) x.rbegin(), x.rend()
#define ios ios_base::sync_with_stdio(false);cin.tie(NULL)
#define ld long double
#define li __int128

using namespace std;
using namespace __gnu_pbds;
using namespace __gnu_cxx;

mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
template<class T> using ordered_set = tree<T, null_type, less<T>, rb_tree_tag,tree_order_statistics_node_update>; ///find_by_order(),order_of_key()
template<int D, typename T>struct vec : public vector<vec<D - 1, T>> {template<typename... Args>vec(int n = 0, Args... args) : vector<vec<D - 1, T>>(n, vec<D - 1, T>(args...)) {}};
template<typename T>struct vec<1, T> : public vector<T> {vec(int n = 0, T val = T()) : vector<T>(n, val) {}};
template<class T1,class T2> ostream& operator<<(ostream& os, const pair<T1,T2>& a) { os << '{' << a.f << ", " << a.s << '}'; return os; }
template<class T> ostream& operator<<(ostream& os, const vector<T>& a){os << '{';for(int i=0;i<sz(a);i++){if(i>0&&i<sz(a))os << ", ";os << a[i];}os<<'}';return os;}
template<class T> ostream& operator<<(ostream& os, const deque<T>& a){os << '{';for(int i=0;i<sz(a);i++){if(i>0&&i<sz(a))os << ", ";os << a[i];}os<<'}';return os;}
template<class T> ostream& operator<<(ostream& os, const set<T>& a) {os << '{';int i=0;for(auto p:a){if(i>0&&i<sz(a))os << ", ";os << p;i++;}os << '}';return os;}
template<class T> ostream& operator<<(ostream& os, const set<T,greater<T> >& a) {os << '{';int i=0;for(auto p:a){if(i>0&&i<sz(a))os << ", ";os << p;i++;}os << '}';return os;}
template<class T> ostream& operator<<(ostream& os, const multiset<T>& a) {os << '{';int i=0;for(auto p:a){if(i>0&&i<sz(a))os << ", ";os << p;i++;}os << '}';return os;}
template<class T> ostream& operator<<(ostream& os, const multiset<T,greater<T> >& a) {os << '{';int i=0;for(auto p:a){if(i>0&&i<sz(a))os << ", ";os << p;i++;}os << '}';return os;}
template<class T1,class T2> ostream& operator<<(ostream& os, const map<T1,T2>& a) {os << '{';int i=0;for(auto p:a){if(i>0&&i<sz(a))os << ", ";os << p;i++;}os << '}';return os;}
int ri(){int x;scanf("%i",&x);return x;}
void rd(int&x){scanf("%i",&x);}
void rd(long long&x){scanf("%lld",&x);}
void rd(double&x){scanf("%lf",&x);}
void rd(long double&x){scanf("%Lf",&x);}
void rd(string&x){cin>>x;}
void rd(char*x){scanf("%s",x);}
template<typename T1,typename T2>void rd(pair<T1,T2>&x){rd(x.first);rd(x.second);}
template<typename T>void rd(vector<T>&x){for(T&p:x)rd(p);}
template<typename C,typename...T>void rd(C&a,T&...args){rd(a);rd(args...);}
//istream& operator>>(istream& is,__int128& a){string s;is>>s;a=0;int i=0;bool neg=false;if(s[0]=='-')neg=true,i++;for(;i<s.size();i++)a=a*10+s[i]-'0';if(neg)a*=-1;return is;}
//ostream& operator<<(ostream& os,__int128 a){bool neg=false;if(a<0)neg=true,a*=-1;ll high=(a/(__int128)1e18);ll low=(a-(__int128)1e18*high);string res;if(neg)res+='-';if(high>0){res+=to_string(high);string temp=to_string(low);res+=string(18-temp.size(),'0');res+=temp;}else res+=to_string(low);os<<res;return os;}

void test(){
	int n=ri(),m=ri();
	ll sm=0;
	vector<ll> imp;
	int pom=0;
	for(int i=0;i<n;i++){
		int a=ri(),b=ri();
		sm+=a;
		imp.pb({b-a});
		pom=b;
	}
	if(n==1){
        printf("%d\n",pom);
        return;
	}
	sort(rall(imp));
	int mogu=m-n;
	for(int i=0;i<n;i++){
		if(imp[i]<=0){
			break;
		}
		if(mogu){
			if(i==n-2){
				if(imp[i]+imp[i+1]>0){
					sm+=imp[i]+imp[i+1];
				}
					break;
			}
			else{
				sm+=imp[i];
				mogu--;
			}
		}
	}
	printf("%lld\n",sm);
}
int main()
{
	int t=ri();
	while(t--){
		test();
	}
	return 0;
}

详细

Test #1:

score: 100
Accepted
time: 1ms
memory: 3812kb

input:

3
4 5
1 100
100 1
100 1
100 1
2 2
1 10
1 10
2 3
100 50
1 1000

output:

400
2
1050

result:

ok 3 number(s): "400 2 1050"

Test #2:

score: 0
Accepted
time: 119ms
memory: 3812kb

input:

100000
6 11
191141536 365120521
799679686 648574232
102602909 467685128
405440859 796808887
384858152 191995380
433392826 195648471
5 13
831367906 510447872
795639287 575551283
811207605 176441088
240156289 946977042
133416463 721098873
5 5
806744021 699586200
630510306 637827160
49223781 641709297
...

output:

3247545200
4106290713
2653993029
5122532137
5570513606
2031887824
2044500908
1857678917
6815058419
2237593918
6646615756
5638337819
3690874076
5497726904
5513905900
5404435094
4705403467
2411992217
3430587752
5098767681
3921151709
1445672728
2692878616
3833748807
2716183054
974485573
6464787173
8839...

result:

ok 100000 numbers

Test #3:

score: 0
Accepted
time: 130ms
memory: 4032kb

input:

100000
2 4
171910845 724506309
259963066 888690008
7 8
953968751 356200645
849910110 806488159
854691378 564448772
233557983 165114038
255658257 12385446
666173054 713885466
955831392 860299505
2 6
813205501 321494719
279407788 802865765
4 8
57425442 736850668
801303313 183904228
13820953 38797054
4...

output:

1613196317
4817503337
1124360484
2136575299
1409199188
3637650680
6262687872
988232227
3651377959
3865729450
967276858
5411226361
5602586585
4319610954
2833710199
4042904612
532626145
3528068938
2661203300
5355268131
284146202
5233667938
6490342667
2369703443
5973463590
5902979500
6331061629
4321393...

result:

ok 100000 numbers

Test #4:

score: 0
Accepted
time: 84ms
memory: 3760kb

input:

100000
1 1
7 4
6 16
7 5
8 2
5 6
8 5
10 4
9 3
10 25
5 10
4 5
8 10
5 10
2 6
5 9
6 8
9 10
8 6
6 7
9 13
6 7
9 8
8 1
6 5
2 10
7 1
2 2
6 4
10 3
10 28
4 3
5 3
2 3
9 10
4 2
5 8
10 8
9 1
6 5
6 6
10 27
10 4
3 6
6 4
5 9
1 5
9 9
1 10
9 2
2 6
7 4
9 27
8 8
4 5
1 1
4 2
6 4
3 9
2 8
7 8
4 4
5 11
9 8
6 4
9 4
9 2
4 3
...

output:

4
48
82
65
65
77
53
37
28
67
59
37
37
59
14
64
7
18
69
38
42
38
49
31
54
40
37
6
6
64
34
10
49
44
14
32
4
50
35
43
43
61
56
79
6
66
68
32
15
48
59
10
41
64
52
14
48
14
47
33
62
52
9
14
41
67
10
37
26
6
46
19
34
24
63
25
49
37
66
44
2
11
34
29
23
13
26
46
41
26
24
18
2
11
55
38
3
31
4
24
25
63
47
3
7...

result:

ok 100000 numbers

Test #5:

score: 0
Accepted
time: 81ms
memory: 5148kb

input:

10
92180 261153
4 1
6 4
1 1
2 4
6 1
3 3
6 3
1 8
7 4
7 4
4 5
8 6
3 4
6 2
8 10
4 2
6 1
5 4
10 3
6 4
8 1
10 4
3 6
9 3
10 7
10 3
3 8
1 6
10 9
4 1
7 9
3 9
9 5
6 8
7 4
1 2
6 8
10 8
4 5
6 8
2 6
8 10
2 1
5 4
9 5
8 5
4 7
5 8
6 2
5 3
4 4
9 7
9 2
4 5
10 7
2 10
5 3
4 10
3 2
9 7
3 9
7 6
10 6
8 4
7 5
3 10
2 2
2 2...

output:

658292
447048
594322
412878
350012
390453
659220
539463
407734
389596

result:

ok 10 numbers