Auto.js食用指南

控件点击是autojs特有的一项功能,基于安卓的无障碍功能的,在软件上有很好的支持,常用于办公软件等......

前言:

软件选择:

auto.js 8.0pro版本(对比4.0版本有阉割,wx和zfb不能点)

  • 客户端模式
  • 服务器模式

    auto.js 4.0版本有一种模式:
  • 客户端模式

设备和电脑连接:

手机:

服务器模式:手机和电脑在同一局域网下相互连接。(手机电脑同wifi远程连接,稳定)

客户端模式:电脑连接以太网(不是虚拟机的wlan端口(wifi)),cmd输入ipconfig查看ipv4地址和手机ip地址比对,前面的192.168.31一样就行,说明在一个ip地址上,就可以连接(推荐4.0版本手机连接)(直接输入电脑ipv4地址即可)

模拟器:

客户端模式:直接模拟器打开客户端模式,输入cmd命令行ipconfig查看的ipv4地址,进行连接,简单快速(模拟器极为推荐)(推荐逍遥模拟器)

桥接模式:模拟器打开桥接模式连接,比如雷电模拟器无法和电脑在同一局域网下,只能使用桥接模式(没有搞成)

模拟器桥接模式的目的:为了模拟器和电脑在同一个虚拟网桥下。

桥接模式就是将主机网卡与虚拟机虚拟的网卡利用虚拟网桥进行通信。

vs.code的配置和使用:

基础配置不用说,也就一个汉化插件。

需要加入的插件有两个:

  • auto.js (4.0版本适用)

    在使用时要先start,然后connect
  • auto.js.pro (pro的8.0版本)

    不需要start,直接连接设备

在使用时如果两个插件同时打开,运行程序时,两个插件同时占有’F5‘运行键,会冲突,所以一般打开一个。

在上方任务栏的帮助栏里可以切换开发者工具,打开看日志

一个快捷键:

ctrl+shift+p:打开命令面板

save on device:保存到指定设备

学习:

1.Auto.js的API文档

Auto.js Pro文档

2.Bilibili学习教程

初级教程

中级教程

获取并分析查找控件属性:

使用方法如图:







阻塞机制:用findOne()、waitFor()、exists()等方法寻找控件会引起线程阻塞,导致脚本莫名卡死。故转而使用findOne(timeout)、findonce(i)方法。

示例:findOne(3000):在3秒内寻找控件。

findOnce(2):寻找筛选出来符合要求的第三个控件。

在findOne找不到指定控件时不妨使用findOne()进行深度搜索。

属性选取的方法(常用className,text,desc,id等进行查找控件):

单属性查找:

className("android.view.View").findOne(5000);

多属性查找:

className("android.widget.EditText").depth(9).drawingOrder(0).indexInParent(2).findOne(5000);

text包含:

textContains("大家都在搜")

text开头:

textStartsWith("QQ")

text结尾:

textEndsWith("QQ")

text正则:

textMatches("\d+")

  1. 关于正则表达式:https://www.runoob.com/regexp/regexp-syntax.html

desc属性类似使用

注意:

软件中id会经常改变的,使用text,desc比id靠谱

UI的使用:

指定UI模式:

带有ui的脚本的的最前面必须使用"ui";指定ui模式,否则脚本将不会以ui模式运行。

  1. ui";

垂直布局与水平布局:

垂直布局:

  1. "ui";
  2. ui.layout(
  3. <vertical>
  4. <button text="第一个按钮"/>
  5. <button text="第二个按钮"/>
  6. </vertical>
  7. );

水平布局:

  1. "ui";
  2. ui.layout(
  3. <horizontal>
  4. <button text="第一个按钮"/>
  5. <button text="第二个按钮"/>
  6. </horizontal>
  7. );

文字框控件:

  1. <text textSize="16sp" textColor="black" text="请输入名称:" />

输入框控件:

  1. <input id="name" />

按钮控件:

  1. <button id="ok1" text="确定" />

图片控件:

  1. <img src="https://www.baidu.com/img/bd_logo1.png"/>

多线程的使用:

1.子线程开启函数

  1. var 子线程 = threads.start(function(){
  2. while(true){
  3. log("子线程");
  4. }
  5. });
  6. 12345

2.子线程停止函数

  1. 子线程.interrupt();
  2. threads.shutDownAll();
  3. //停止所有通过threads.start()启动的子线程。

3.等待线程执行完成

  1. 子线程.join([timeout]);
  2. //等待线程执行完成。如果timeout为0,则会一直等待直至该线程执行完成;否则最多等待timeout毫秒的时间。

4.返回线程是否存活

  1. 子线程.isAlive()
  2. //返回线程是否存活。

5.等待线程开始执行

  1. 子线程.waitFor()
  2. //等待线程开始执行。调用threads.start()以后线程仍然需要一定时间才能开始执行

5.单次定时器

  1. var 子线程 = threads.start(function(){
  2. setTimeout(function(){
  3. //do something
  4. }, 1000);
  5. });
  6. 子线程.setTimeout(function(){
  7. //do something
  8. }, 1000);

6.循环定时器

  1. var 子线程 = threads.start(function(){
  2. setInterval(function(){
  3. //do something
  4. }, 1000);
  5. });
  6. 子线程.setInterval(function(){
  7. //do something
  8. }, 1000);

7.多线程里的定时器

  1. var thread = threads.start(function () {
  2. log("先运行这一句,然后开启定时器,1s后输出\"子线程:\",开启定时器后就继续运行,开启单次定时器,运行主线程");
  3. //在子线程执行的定时器
  4. setInterval(function () {
  5. log("子线程:");
  6. }, 1000);
  7. });//只能放在前面,不然运行到主线程,若有死循环就没法开启子线程
  8. //等待子线程启动
  9. thread.waitFor();
  10. //在子线程执行的定时器
  11. thread.setTimeout(function () {//单次定时器
  12. //在子线程执行的定时器
  13. log("运行到此定时器后,2s后输出此行");
  14. }, 2000);
  15. for(i=0;i<5;i++) {
  16. log("当前线程为主线程-"+i);
  17. sleep(3000)
  18. }
  19. sleep(5000);
  20. thread.interrupt();
  21. exit()

8.弹窗检测

  1. var 弹窗检测 = threads.start(function () {
  2. //在子线程执行的定时器
  3. setInterval(function () {
  4. log("弹窗检测中");
  5. if(){
  6. toastLog("弹窗出现");
  7. }
  8. }, 2000);
  9. });

注意:

子线程用完记得关闭thread.interrupt();

下面是一些源码成品,可直接使用:

脚本体验卡:

  1. function IntTime() {
  2. try {
  3. var recode_suning = http.get("http://quan.suning.com/getSysTime.do");
  4. var suningTime = recode_suning.body.json();
  5. return suningTime.sysTime1;
  6. } catch (e) {}
  7. }
  8. let ntime = 20220817210627;//设置截至时间
  9. if (toTime() < ntime || IntTime() < ntime) {
  10. toastLog("正常");
  11. //代码放这里运行
  12. } else {
  13. toastLog("已过期");
  14. engines.stopAll();
  15. }
  16. function toTime() {
  17. return new java.text.SimpleDateFormat("yyyyMMddHHmmss").format(new Date());
  18. }

屏幕解锁:

  1. setScreenMetrics(1080, 2340);
  2. var { password } = hamibot.env;
  3. var { select } = hamibot.env;
  4. var { slide_time } = hamibot.env;
  5. function number_click(num) {
  6. var number = text(num).findOne().bounds();
  7. click(number.centerX(), number.centerY());
  8. }
  9. function scroll() {
  10. if (select == 'a') {
  11. swipe(device.width / 2, device.height * 12 / 15, device.width / 2, device.height * 6 / 15, Number(slide_time));
  12. } else {
  13. swipe(device.width / 2, device.height * 6 / 15, device.width / 2, device.height * 12 / 15, Number(slide_time));
  14. }
  15. }
  16. function input_password() {
  17. for (var i = 0; i < password.length; i++) {
  18. switch(password[i]) {
  19. case '1': number_click('1'); break;
  20. case '2': number_click('2'); break;
  21. case '3': number_click('3'); break;
  22. case '4': number_click('4'); break;
  23. case '5': number_click('5'); break;
  24. case '6': number_click('6'); break;
  25. case '7': number_click('7'); break;
  26. case '8': number_click('8'); break;
  27. case '9': number_click('9'); break;
  28. case '0': number_click('0'); break;
  29. default: toast("密码输入错误");
  30. exit();
  31. }
  32. }
  33. }
  34. while (!device.isScreenOn()) {
  35. device.wakeUpIfNeeded();
  36. sleep(1000);
  37. scroll();
  38. if (password) {
  39. while (!text('1').exists()) scroll();
  40. input_password();
  41. }
  42. }
  43. home();

屏幕解锁(json)

  1. [
  2. {
  3. "name": "password",
  4. "type": "text",
  5. "label": "开屏密码",
  6. "help": "开屏密码只能是数字形式,比如:123456,如果无密码不需要填写"
  7. },
  8. {
  9. "name": "select",
  10. "type": "select",
  11. "label": "亮屏后是上滑开锁还是下滑",
  12. "options": {
  13. "a": "上滑",
  14. "b": "下滑"
  15. },
  16. "validation": "required",
  17. "help": "如果不需要滑动就选择默认上滑"
  18. },
  19. {
  20. "name": "slide_time",
  21. "type": "number",
  22. "label": "滑动时间(以毫秒ms为单位)",
  23. "validation": "required",
  24. "help": "默认为10ms,因不同手机而异,如果解锁不成功可以尝试其他数值"
  25. }
  26. ]

联众接码:

  1. // 读取图片
  2. var imgPath = '/sdcard/1.png'
  3. var img = images.read(imgPath)
  4. // 配置文件, 如果要使用以下代码, 请更改username和password
  5. var config = {
  6. baseUrl: 'https://v2-api.jsdama.com/upload',
  7. headers: {
  8. "Host": 'v2-api.jsdama.com',
  9. "Connection": 'keep-alive',
  10. "Accept": 'application/json, text/javascript, */*; q=0.01',
  11. "Content-Type": 'text/json',
  12. "User-Agent": "Mozilla/5.0 (iPhone; U; CPU iPhone OS 4_3_2 like Mac OS X; en-us) AppleWebKit/533.17.9 (KHTML, like Gecko) Version/5.0.2 Mobile/8H7 Safari/6533.18.5 Quark/2.4.2.986"
  13. },
  14. softwareSecret: 'FjXYcWGeVRaReAuW92PrsTKnkG9HuLoy3DXhJc5H',
  15. softwareId: '12330',
  16. username: 'autojs',
  17. password: 'lianzhong',
  18. captchaData: images.toBase64(img, format = "png"),
  19. captchaType: '1001',
  20. captchaMinLength: '4',
  21. captchaMaxLength: '4'
  22. }
  23. // 配置参数中有三个参数需要注意一下:
  24. // captchaType:图像类型, 图像类型有很多种,比如汉字,中英文,车牌号,箭头等,
  25. // 具体请查看 图像类型
  26. // captchaMinLength:验证码最小长度
  27. // captchaMaxLength:验证码最大长度
  28. // 识别图片
  29. var url = config.baseUrl
  30. var data = {
  31. softwareSecret: config.softwareSecret,
  32. softwareId: config.softwareId,
  33. username: config.username,
  34. password: config.password,
  35. captchaData: config.captchaData,
  36. captchaType: config.captchaType,
  37. captchaMinLength: config.captchaMinLength,
  38. captchaMaxLength: config.captchaMaxLength,
  39. }
  40. var options = {
  41. headers: config.headers
  42. }
  43. try {
  44. http.__okhttp__.setTimeout(3e4);
  45. var res = http.postJson(url, data, options);
  46. log('请求开始')
  47. var html = res.body.json();
  48. log('请求结束')
  49. log(html)
  50. if (html.code === '0') {
  51. console.log('联众识别结果=', html.data.recognition)
  52. // return html.data.recognition
  53. } else {
  54. log("识别图片出现错误,请检查账号信息是否正确")
  55. }
  56. } catch (e) {
  57. log(e)
  58. }

dy达人广场采集:

  1. device.keepScreenOn(3600 * 1000)
  2. while (1) {
  3. //第一
  4. var 粉丝数 = className("android.view.View").textContains("粉丝").boundsInside(0, 1/5*device.height,device.width, device.height).findOne(5000)
  5. if (粉丝数) {
  6. click(粉丝数.bounds().centerX(), 粉丝数.bounds().centerY())
  7. // press(粉丝数.bounds().centerX() - 200, 粉丝数.bounds(), 500);
  8. sleep(2000)
  9. var 昵称 = className("android.widget.TextView").id("lem").findOne(5000)
  10. if (昵称) {
  11. log(昵称.text())
  12. files.append("/sdcard/抖音数据.txt", '\n' + 昵称.text(), [encoding = "utf-8"]);
  13. sleep(200);
  14. var 抖音号 = className("android.widget.TextView").textContains("抖音号").findOne(5000)
  15. if (抖音号) {
  16. log(抖音号.text())
  17. files.append("/sdcard/抖音数据.txt", '\n' + 抖音号.text(), [encoding = "utf-8"]);
  18. var 更多 = className("android.widget.ImageView").desc("更多").findOne(5000)
  19. if (更多) {
  20. click(更多.bounds().centerX(), 更多.bounds().centerY())
  21. sleep(500)
  22. var 发私信 = className("android.widget.TextView").text("发私信").findOne(5000)
  23. if (发私信) {
  24. click(发私信.bounds().centerX(), 发私信.bounds().centerY())
  25. sleep(2000)
  26. var 文字按钮 = className("android.widget.ImageView").boundsInside(0, 5 / 6 * device.height, device.width, device.height).findOne(2000)
  27. if (文字按钮) {
  28. click(文字按钮.bounds().centerX(), 文字按钮.bounds().centerY())
  29. }
  30. sleep(1000)
  31. setText("你好");
  32. sleep(500)
  33. var 发送 = className("android.widget.ImageView").desc("发送").findOne(5000)
  34. if (发送) {
  35. click(发送.bounds().centerX(), 发送.bounds().centerY())
  36. back()
  37. sleep(500)
  38. back()
  39. }
  40. }
  41. }
  42. }
  43. }
  44. }
  45. //第一个
  46. var 粉丝数 = className("android.view.View").textContains("粉丝").boundsInside(0, 1 / 5 * device.height, device.width, device.height).findOne(5000)
  47. if (粉丝数) {
  48. log(粉丝数.text())
  49. files.append("/sdcard/抖音数据.txt", '\n' + 粉丝数.text(), [encoding = "utf-8"]);
  50. }
  51. // var 带货等级 = className("android.view.View").textContains("带货等级").boundsInside(0, 1 / 5 * device.height, device.width, device.height).findOne(5000)
  52. var 带货等级 = className("android.widget.TextView").textContains("带货等级").boundsInside(0, 1 / 5 * device.height, device.width, device.height).findOne(5000)
  53. if (带货等级) {
  54. log(带货等级.text())
  55. files.append("/sdcard/抖音数据.txt", '\n' + 带货等级.text(), [encoding = "utf-8"]);
  56. }
  57. files.append("/sdcard/抖音数据.txt", '\n------------------------------');
  58. swipe(device.width / 2, device.height * 5 / 8, device.width / 2, device.height * 3 / 8, 500);
  59. sleep(3000)
  60. }

百度文字识别:

  1. //截图当前屏幕并识别截图中的文字
  2. auto()
  3. //请求截图
  4. if(!requestScreenCapture()){
  5. toast("请求截图失败");
  6. exit();
  7. }
  8. log("识别开始")
  9. requestUrl="https://aip.baidubce.com/rest/2.0/ocr/v1/general_basic"
  10. accessToken = '24.45e9e852ec0cc0f41a268e11ce7b2f3f.2592000.1535634423.282335-10386148'
  11. requestUrl = requestUrl + "?access_token=" + accessToken
  12. imgFile="/sdcard/test.jpg"
  13. function img64(imgFile){
  14. var img = captureScreen();
  15. let img64=images.toBase64(img)
  16. return img64
  17. }
  18. imageBase64=img64(imgFile)
  19. imageBase64=encodeURI(imageBase64)
  20. console.show();
  21. var res = http.post(requestUrl, {
  22. headers: {
  23. 'Content-Type': 'application/x-www-form-urlencoded'
  24. },
  25. image:imageBase64,
  26. image_type:"BASE64",
  27. });
  28. var html = res.body.string();
  29. log(html)
  30. log("识别结束")

auto.jspro商店整蛊脚本:

  1. /*
  2. * @Author: 旭阳
  3. * @QQ:1912452912
  4. * @versioin: 1.0
  5. * @Date: 2022-09-06 15:46:30
  6. */
  7. "ui";
  8. var resources = context.getResources();
  9. var statusBarHeight = resources.getDimensionPixelSize(resources.getIdentifier('status_bar_height', 'dimen', 'android'));//通知栏高度
  10. var navigationBarHeight = getNavigationBarHeight()//导航栏高度
  11. var deviceheight = device.height - statusBarHeight - navigationBarHeight
  12. var rect = new android.graphics.Rect
  13. ui.layout(
  14. <frame w="*" h="*" >
  15. <vertical id="main" w="450px" h="200px" layout_gravity="center" bg="#00ffff">
  16. <text h="100px" text="你愿意给我10元红包吗" textColor="#000000" gravity="center"/>
  17. <frame>
  18. <text id="touch" w="200px" h="100px" text="愿意" bg="#363636" gravity="center" textColor="#ffffff" />
  19. <text id="fake" w="200px" h="100px" layout_gravity="right|bootom"/>
  20. </frame>
  21. </vertical>
  22. <text id="untouch" w="200px" h="100px" text="不愿意" bg="#363636" textColor="#ffffff" gravity="center"/>
  23. </frame>
  24. )
  25. setTimeout(function() {
  26. ui.fake.getBoundsOnScreen(rect)
  27. ui.untouch.x = rect.left
  28. ui.untouch.y = rect.top - statusBarHeight
  29. }, 50)
  30. ui.touch.on("click", () => {
  31. app.startActivity({
  32. data: "mqqapi://card/show_pslcard?src_type=internal&source=sharecard&version=1&uin=1912452912"
  33. });
  34. toast("请加QQ1912452912并发10元红包")
  35. })
  36. ui.untouch.on("touch_down", () => {
  37. ui.untouch.getBoundsOnScreen(rect)
  38. let l = rect.left
  39. let t = rect.top - statusBarHeight
  40. let r = rect.right
  41. let b = rect.bottom - statusBarHeight
  42. let w = rect.width()
  43. let h = rect.height()
  44. //以下if-else语句是为了保持按钮在屏幕内并尽量随机变换按钮位置
  45. if (l < w) {
  46. ui.untouch.x = random(l + w, device.width - w)
  47. if (t < h || new Date().getTime % 2)
  48. ui.untouch.y = random(t + h, deviceheight - h)
  49. else
  50. ui.untouch.y = random(0, b - h)
  51. } else if ((device.width - r) < w) {
  52. ui.untouch.x = random(0, r - w)
  53. if ((deviceheight - b) < h || new Date().getTime % 2)
  54. ui.untouch.y = random(0, b - h)
  55. else
  56. ui.untouch.y = random(t + h, deviceheight - h)
  57. } else if (new Date().getTime % 2) {
  58. ui.untouch.x = random(l + w, device.width - w)
  59. if (t < h || new Date().getTime % 2)
  60. ui.untouch.y = random(t + h, deviceheight - h)
  61. else
  62. ui.untouch.y = random(0, b - h)
  63. } else {
  64. ui.untouch.x = random(0, r - w)
  65. if ((deviceheight - b) < h || new Date().getTime % 2)
  66. ui.untouch.y = random(0, b - h)
  67. else
  68. ui.untouch.y = random(t + h, deviceheight - h)
  69. }
  70. })
  71. function getNavigationBarHeight() {
  72. var navigationBarHeight = 0;
  73. var rid = context.getResources().getIdentifier("config_showNavigationBar", "bool", "android");
  74. if (rid != 0) {
  75. var resourceId = context.getResources().getIdentifier("navigation_bar_height", "dimen", "android");
  76. navigationBarHeight = context.getResources().getDimensionPixelSize(resourceId);
  77. }
  78. return navigationBarHeight;
  79. }

Auto.js食用指南的更多相关文章

  1. 【vue.js权威指南】读书笔记(第一章)

    最近在读新书<vue.js权威指南>,一边读,一边把笔记整理下来,方便自己以后温故知新,也希望能把自己的读书心得分享给大家. [第1章:遇见vue.js] vue.js是什么? vue.j ...

  2. Node.js开发指南中的例子(mysql版)

    工作原因需要用到nodejs,于是找到了<node.js开发指南>这本书来看看,作者BYVoid 为清华大学计算机系的高材生,年纪竟比我还小一两岁,中华地广物博真是人才辈出,佩服. 言归正 ...

  3. 《JS权威指南学习总结》

    JS权威指南学习总结:http://www.cnblogs.com/ahthw/category/652668.html

  4. 《JS权威指南学习总结--开始简介》

    本书共分成了四大部分: 1.JS语言核心 2.客户端JS 3.JS核心参考 4.客户端JS核心参考 其中 <JS权威指南学习总结--1.1语法核心> 是:第一部分JS语言核心 各章节重点 ...

  5. 《JS权威指南学习总结--1.1语言核心》

    1.1语言核心 --本节主要介绍<js权威指南>基础部分各章讲解内容和一些简单的示例 本小节内容: 一.第二章讲解js注释.分号和Unicode,第三章主要讲解js变量和赋值 简单示例: ...

  6. Sencha Cmd 6 和 Ext JS 6 指南文档(部分官方文档中文翻译)

    近期组织了几个程序员网友,正在翻译一部分官方的Sencha Cmd 6 和 Ext JS 6 指南文档. 眼下还没翻译完,大家能够先看看 Sencha Cmd 6 和 Ext JS 6 指南文档  ( ...

  7. 学习Nodejs:《Node.js开发指南》微博项目express2迁移至express4过程中填的坑

    <Node.js开发指南>项目地址https://github.com/BYVoid/microblog好不容易找到的基础版教程,但书中是基于express2的,而现在用的是express ...

  8. Auto.js 初试-Android开发JS利器

    GitHub地址:https://github.com/hyb1996/Auto.js 文档地址:https://hyb1996.github.io/AutoJs-Docs/#/?id=%E7%BB% ...

  9. 【Auto.js images.matchTemplate() 函数的特点】

    Auto.js  images.matchTemplate() 函数的特点 官方文档:https://hyb1996.github.io/AutoJs-Docs/#/images?id=imagesm ...

  10. d3.js 入门指南 - 仪表盘

    D3的全称是Data-Driven Documents(数据驱动的文档),是一个用来做数据可视化的JavaScript函数库,而JavaScript文件的后缀通常为.js,所以D3被称为D3.js. ...

随机推荐

  1. 二进制安装Kubernetes(k8s) v1.23.7 IPv4/IPv6双栈

    二进制安装Kubernetes(k8s) v1.23.7 IPv4/IPv6双栈 Kubernetes 开源不易,帮忙点个star,谢谢了 介绍 kubernetes二进制安装 后续尽可能第一时间更新 ...

  2. Go语言微服务框架go-micro(入门)

    Micro用于构建和管理分布式系统,是一个工具集,其中go-micro框架是对分布式系统的高度抽象,提供分布式系统开发的核心库,可插拔的架构,按需使用 简单示例 编写protobuf文件: synta ...

  3. 自学C#,要懂得善用MSDN

    很多初学者学习编程,都会通过看别人写的教程.或者录制的视频,来学习. 这是一个非常好的途径,因为这个是非常高效的. 但是这样,存在两个问题: 1.教程不够全面:任何再好的教程,都无法囊括所有的知识点, ...

  4. Marior去除边距和迭代内容矫正用于自然文档矫正

    一.简要介绍 本文简要介绍了论文" Marior: Margin Removal and Iterative Content Rectification for Document Dewar ...

  5. java封装和关键字

    一.封装 封装:告诉我们如何正确设计对象的属性和方法 对象代表什么,就得封装对应的数据,并提供数据对应的行为 封装的好处: 让编程变得很简单,有什么事,找对象,调方法 降低学习成本,可以少学,少记,或 ...

  6. nginx配置文件编写及日志文件相关操作

    nginx配置文件编写及日志文件相关操作 目录 nginx配置文件编写及日志文件相关操作 nginx主配置文件扩展详解 部署nginx网站 注意事项 Nginx虚拟主机 nginx配置虚拟主机的三种方 ...

  7. 2023-04-30:用go语言重写ffmpeg的resampling_audio.c示例,它实现了音频重采样的功能。

    2023-04-30:用go语言重写ffmpeg的resampling_audio.c示例,它实现了音频重采样的功能. 答案2023-04-30: resampling_audio.c 是 FFmpe ...

  8. 2023-04-14:n对情侣坐在连续排列的 2n 个座位上,想要牵到对方的手, 人和座位由一个整数数组 row 表示,其中 row[i] 是坐在第 i 个座位上的人的ID, 情侣们按顺序编号,第一对

    2023-04-14:n对情侣坐在连续排列的 2n 个座位上,想要牵到对方的手, 人和座位由一个整数数组 row 表示,其中 row[i] 是坐在第 i 个座位上的人的ID, 情侣们按顺序编号,第一对 ...

  9. 2022-07-28:以下go语言代码输出什么?A:AA;B:AB;C:BA;D:BB。 package main import ( “fmt“ ) func main() { f

    2022-07-28:以下go语言代码输出什么?A:AA:B:AB:C:BA:D:BB. package main import ( "fmt" ) func main() { f ...

  10. 2022-07-11:给定n位长的数字字符串和正数k,求该子符串能被k整除的子串个数。 (n<=1000,k<=100)。 来自微众。4.11笔试。

    2022-07-11:给定n位长的数字字符串和正数k,求该子符串能被k整除的子串个数. (n<=1000,k<=100). 来自微众.4.11笔试. 答案2022-07-11: 动态规划. ...