class="markdown_views prism-dracula">


解题思路:
这个题做法很多,我直接按照题意模拟了一下,复杂度O(n),记录一下右边界,每次得到算术平方根后与上一个结果进行比较,相同则放到数组右边界,否则更新上一个结果。
代码如下:
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define inf 0x3f3f3f3f
#define MOD 1000000007
#define mem0(a) memset(a,0,sizeof(a))
#define mem1(a) memset(a,-1,sizeof(a))
#define meminf(a) memset(a,inf,sizeof(a))
typedef long long ll;
typedef unsigned long long ull;
using namespace std;
int poker[100010];
int main()
{
std::ios::sync_with_stdio(false);
cin.tie(0);
int n,t,a,li=0,mr=-1;
cin>>n;
for(int i=0;icin>>a;
t=n-i;
int cur=sqrt(t);
if(cur==li)
{
poker[mr]=a;
mr++;
}
else
{
poker[cur]=a;
li=cur;
if(cur>mr)mr=cur+1;
}
}
for(int i=1;i<=n;i++)cout<' ';
cout<
还有用动态数组的一种写法,是将数组逆序存了一下,利用insert()函数插入下标之前的特点。最后的输出还是第一次见。。一直都是用迭代器的,还有这种操作??
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define inf 0x3f3f3f3f
#define MOD 1000000007
#define mem0(a) memset(a,0,sizeof(a))
#define mem1(a) memset(a,-1,sizeof(a))
#define meminf(a) memset(a,inf,sizeof(a))
typedef long long ll;
typedef unsigned long long ull;
using namespace std;
int a[100010];
int main()
{
std::ios::sync_with_stdio(false);
cin.tie(0);
int n;
cin>>n;
vector<int> res;
for(int i=1;i<=n;i++)scanf("%d",&a[n-i+1]);
for(int i=1;i<=n;i++)res.insert(res.begin()+sqrt(i)-1,a[i]);
;
return 0;
}