为什么超时

bc02 2022-11-06 20:31:32 2022-11-07 17:48:51 2
#include <bits/stdc++.h> //有尖括号的
using namespace std;
 long long int  c[100000001],n,d[100000001]; 
int bd(){
	for(long long int i=1;i<n;i++){
		for(long long int j=i+1;j<=n;j++)
		{
			if(c[j]>c[i])
			{
				d[i]=j;
				break;
			}
		 }
		 cout<<d[i]<<endl;
	}
	}
int main(){
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		cin>>c[i];
	}
	bd();
	cout<<0;
	return 0;
} 
{{ vote && vote.total.up }}

共 2 条回复

tctm92 坤坤侠
#include<iostream>
using namespace std;
int n,a[100005],dp[100005];
int main(){
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>a[i];
	}
	for(int i=1;i<=n;i++){
		for(int j=i+1;j<=n;j++){
			if(a[i]<a[j]){
				dp[i]=j;
				break;
			}
			else if(j==n && a[i]>=a[j]){
				dp[i]=0;
			}
		}
	}
	for(int i=1;i<=n;i++){
		cout<<dp[i]<<endl;
	}
	return 0;
}
tctm92 坤坤侠

用动态规划