当前位置: 首页 > news >正文

怎样做有趣的视频网站seo在线培训

怎样做有趣的视频网站,seo在线培训,黄村做网站的公司,网页美工设计多少钱一、 题目描述: 小红有一个01字符串,她可以进行最多k次提作,每次操作可以交换相邻的两个字符,问可以得到的字典序最小的字符串是什么 输入描述: 一行两个整数 n 和 k,表示字符串的长度和可以进行的操作…

一、

题目描述:

小红有一个01字符串,她可以进行最多k次提作,每次操作可以交换相邻的两个字符,问可以得到的字典序最小的字符串是什么

输入描述:

一行两个整数 n 和 k,表示字符串的长度和可以进行的操作次数。
接下来一行一个长度为 n 的 01 字符串。

1<= n <= 1 0 5 10^5 105

1<= k <= 1 0 9 10^9 109

输出描述:

输出一个长度为 n 的字符串,表示字典序最小的字符串。

示例输入

5 2
01010

输出

00101

题解

双指针模拟,将第一个出现在1后面的0与最前面的1交换
判断需要交换次数大于或者小于 k,后移指向 1 的指针,满足交换次数

import java.util.Scanner;public class A {public static void main(String[] args) {Scanner in = new Scanner(System.in);int n = in.nextInt();int k = in.nextInt();in.nextLine();char[] input = in.nextLine().toCharArray();int indexOne = 0, indexZero = -1;while (k > 0) {// 找第一个是1的for (int i = indexOne; i < input.length; i++) {if (input[i] == '1') {indexOne = i;break;}}// 找第一个1后面是0的for (int i = indexOne; i < input.length; i++) {if (input[i] == '0') {indexZero = i;break;}}int index = indexZero - indexOne;if (k >= index) {k = k - index;char c = input[indexZero];input[indexZero] = input[indexOne];input[indexOne] = c;}else {indexOne = indexZero - k;char c = input[indexZero];input[indexZero] = input[indexOne];input[indexOne] = c;break;}}for (char c:input) {System.out.print(c);}}
}

二、

讨厌鬼有一个长度为 n 的数组,他想知道这个数组有多少个子序列是一个排列?
子序列的定义:数组删除若干个元素(也可以不删)后得到的新数组。
排列的定义:长度为 m 的数组,1 到 m 每个元素都出现过,且恰好出现1次。

输入描述:

第一行输入一个整数 n (1<=n<= 1 0 5 10^5 105)

第二行输入 n 个整数 a i a_i ai (1<= a i a_i ai<= 1 0 9 10^9 109)

输出描述:

一行一个整数,表示有多少个子序列是一个排列。由于答案过大,请将答案对 1 0 9 10^9 109+ 7 取模后输出

示例输入:

6
1 1 5 2 3 4

输出:

10

解释:

符合要求的子序列有:{1},{1},{1,2},{1,2},{1,2,3},{1,2,3},{1,2,3,4},{1,2,3,4},{1,5,2,3,4},{1,5,2,3,4}共10个

题解

记录每个数字出现的次数
根据乘法原理,当前数字可以组合成的合法子序列个数为 cur * cnt[i],累加

import java.util.*;public class Solution {public static void main(String[] args) {int[] cnt = new int[(int)1e5+10];int mod = (int)1e9 + 7;Scanner in = new Scanner(System.in);int n = in.nextInt();int[] nums = new int[n];for (int i = 0; i < n; i++) {nums[i] = in.nextInt();cnt[nums[i]]++;//出现的次数 cnt[1]=2}// 根据乘法原理,当前数字可以组合成的合法子序列个数为cur * cnt[i],累加即可int cur = 1;int res = 0;for (int i = 1; i < cnt.length; i++) {//cur记录的是:前面出现多少种子序列了,cnt[i]下一个的次数,结合上次相乘就是这次包含进去的序列个数cur = cur * cnt[i];if(cur == 0)break;res += cur;}System.out.println(res);}
}
http://www.wangmingla.cn/news/108813.html

相关文章:

  • 做简历做得好的网站网站统计系统
  • 垂直网站建设免费做网站
  • dreamweaver 网站框架一站式营销平台
  • 佛山营销手机网站建设企业网站建设方案
  • 公司设计网站建设app推广拉新接单平台
  • 佛山网站建设哪家效果好足球世界排名国家
  • 北京 网站设计 地址通州百度关键词怎么设置
  • 用网站素材做logo网络推广平台代理
  • 旅游网站设计内容百度推广在哪里
  • 中国建设银行网站特点西安竞价托管
  • 建设网站平台合同范本网络优化培训要多少钱
  • 可以做红娘的相亲网站纹身网站设计
  • 西安网站挂标网络优化工程师为什么都说坑人
  • 代码网站怎么做的友情链接交换群
  • 哈尔滨模板建站平台长沙官网seo技术厂家
  • 宁陵视频网站建设营销方案怎么写?
  • 网络工程专业毕业生设计优化培训学校
  • 政府网站建设进程seo臻系统
  • 平台期什么意思百度站长工具seo
  • 合肥瑶海区网站建设价格tool站长工具
  • 可以做动画的网站有哪些深圳全网推广公司
  • 西安做企业网站广告宣传
  • 如何购买网站域名快速seo关键词优化技巧
  • 黄石网站设计公司关键词seo服务
  • 常州专业房产网站建设google app下载
  • asp源代码网站neotv
  • 政府网站建设要点丈哥seo博客工具
  • 网站建设推进表制作网站模板
  • 网站建设选择北京华网天下上海百度竞价托管
  • 黄山公司做网站河北seo平台