【Go语言入门100题】027 出租 (20 分) Go语言 | Golang-阿里云开发者社区

开发者社区> 小生凡一> 正文

【Go语言入门100题】027 出租 (20 分) Go语言 | Golang

简介: 【Go语言入门100题】027 出租 (20 分) Go语言 | Golang
+关注继续查看

L1-027 出租 (20 分) Go语言|Golang

image.png

一时间网上一片求救声,急问这个怎么破。其实这段代码很简单,index数组就是arr数组的下标,index[0]=2 对应 arr[2]=1,index[1]=0 对应 arr[0]=8,index[2]=3 对应 arr[3]=0,以此类推…… 很容易得到电话号码是18013820100。


本题要求你编写一个程序,为任何一个电话号码生成这段代码 —— 事实上,只要生成最前面两行就可以了,后面内容是不变的。


输入格式:

输入在一行中给出一个由11位数字组成的手机号码。


输出格式:

为输入的号码生成代码的前两行,其中arr中的数字必须按递减顺序给出。


输入样例1:

18013820100

结尾无空行


输出样例1:

int[] arr = new int[]{8,3,2,1,0};
int[] index = new int[]{3,0,4,3,1,0,2,4,3,4,4};


结尾无空行


思路:

读懂题目很重要!


输出的第一个列表其实就是这个电话号码的数字,只不过是去除了重复的数字再排一下序而已。

那第二个列表其实就是这个电话号码中的数字在第一个列表的下标位置而已!!


比如说:

index列表的第一个是3,就表示电话号码的第一个数字是arr列表的下标为3的数字,就是1。

index列表的第二个是0,就表示电话号码的第二个数字是arr列表的下标为0的数字,就是8。


那我们要做的就是反过来的操作。用这个电话号码去推这两个列表


先把第一个列表搞定,第一个列表就是提取出这个电话号码里面的数字然后去重再进行排序麻

第二个列表就是在第一个列表的基础上去遍历这个电话号码,去查询这个电话号码的数字在第一个列表里面的什么位置,记录下标就行了~

代码如下:

package main

import (
    "fmt"
    "sort"
    "strconv"
)

func main() {
    var str string
    var opList []int
    _,_=fmt.Scan(&str)
    phoneMap := make(map[rune]int)
    for _,i := range str{  //用map去存这个电话的数字
        phoneMap[i-'0'] = 1
    }
    for i:=0;i<=9;i++ {
        if phoneMap[rune(i)] == 1 {
            opList = append(opList, i) //拿到去重后的电话数字列表
        }
    }
    sort.Ints(opList)  // sort正序排
    var opListReserve []int
    for i:=len(opList)-1 ; i>=0 ; i-- {
        opListReserve = append(opListReserve, opList[i]) // 要倒序排
    }
    s:=""
    op := ""
    for _,i:= range opListReserve{
        op+=strconv.Itoa(i)+","
    }
    for _,i := range str{       //遍历一遍电话号码
        for index,j := range opListReserve{     // 再遍历一遍去重的电话号码
            if i-'0' == rune(j) {                   // 如果是等于的话,就记录去重列表中的电话号码的下标
                s+=strconv.Itoa(index)+","
            }
        }
    }
    fmt.Printf("int[] arr = new int[]{%s};\n",op[:len(op)-1])   // 把最后一个逗号省去了
    fmt.Printf("int[] index = new int[]{%s};",s[:len(s)-1])
}

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
9497 0
使用SSH远程登录阿里云ECS服务器
远程连接服务器以及配置环境
2464 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
13186 0
windows server 2008阿里云ECS服务器安全设置
最近我们Sinesafe安全公司在为客户使用阿里云ecs服务器做安全的过程中,发现服务器基础安全性都没有做。为了为站长们提供更加有效的安全基础解决方案,我们Sinesafe将对阿里云服务器win2008 系统进行基础安全部署实战过程! 比较重要的几部分 1.
9055 0
阿里云服务器ECS登录用户名是什么?系统不同默认账号也不同
阿里云服务器Windows系统默认用户名administrator,Linux镜像服务器用户名root
4012 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,云吞铺子总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系统盘、创建快照、配置安全组等操作如何登录ECS云服务器控制台? 1、先登录到阿里云ECS服务器控制台 2、点击顶部的“控制台” 3、通过左侧栏,切换到“云服务器ECS”即可,如下图所示 通过ECS控制台的远程连接来登录到云服务器 阿里云ECS云服务器自带远程连接功能,使用该功能可以登录到云服务器,简单且方便,如下图:点击“远程连接”,第一次连接会自动生成6位数字密码,输入密码即可登录到云服务器上。
21908 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
6895 0
+关注
小生凡一
你好呀!
157
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载