C. Make It Good【1200 / 思维 、贪心】

在这里插入图片描述
https://codeforces.com/problemset/problem/1385/C
在这里插入图片描述
找到这样的一个山峰

#include<bits/stdc++.h>
using namespace std;
const int N=1e5*2+10;
int a[N];
int main(void) 
{
	int t; cin>>t;
	while(t--)
	{
		int n; cin>>n;
		for(int i=0;i<n;i++) cin>>a[i];
		int flag=0,pos=0;
		for(int i=n-1;i>=0;i--)
		{
			if(a[i]>a[i-1]) flag=1;
			if(flag&&i-1>=0&&a[i-1]>a[i]) 
			{
				pos=i;
				break;
			}
		}
		cout<<pos<<endl;
	}
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
(1)在内核中实现缺页次数统计: 1.cd /usr/sec/linux-2.6.32.60 // 切换到预编译内核 2.sudo gedit arch/x86/mm/fault.c / /编辑fault.c 3.Unsigned long volatile pfcount //在fault.c中定义缺页次数全局变量. 4.将pfcount加入到do_page_fault中,用以统计缺页次数. 5.sudo gedit include/linux/mm.h //声明全局变量pfcount到头文件mm.h. 6.在extern int page_cluster下面添加代码 Extern unsigned long volatile pfcount; 7.Sudo gedit kernel/kallsym.c // 导出pfcount全局变量,整个内核都可以访问. 8.在最后一行添加代码EXPORT_SYMBOL(pfcount); (2)编译安装新内核: 1.sudo make mrproper //删除原来编译产生的垃圾 2.sudo cp /boot/config-3.2.0-29-generic-pag .config //导入原系统的内核配置 3.sudo make odlconfig; //更改配置 4.Sudo make clean; 5.make bzImage //编译内核 6.make modules //编译内核模块 7.make modules_install //安装内核模块 8.make install //安装内核 9.Sudo reboot //重新启动Linux系统 (3)新建内核模块,通过/proc实现用户态下查看缺页次数: 1.make source //创建source文件,存放编写的模块程序. 2.cd source/ //切换到source目录. 3.gedit pf.c// 新建用于构建模块的代码 4.Gedit Makefile //构建Makefile 5.在Makefile中添加 obj-m := pf.o 6.Sudo make -C /usr/src/linux-2.6.32.60 SUBDIRS=$PWD modules //编译、构建内核模块 7.sudo insmod pf.ko //加载模块到内核 8.sudo lsmod | grep pf //验证pf内核模块是否加载到内核进程中,运行命令出现pf信息说明加载成功 9.cat /proc/pf/pfcount //查看缺页统计次数通过以上步骤,你能帮我解读实验的结果吗
06-08

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值