【Go语言入门100题】006 连续因子 (20 分) Go语言|Golang

简介: L1-006 连续因子 (20 分) Go语言|Golang一个正整数 N 的因子中可能存在若干连续的数字。例如 630 可以分解为 3×5×6×7,其中 5、6、7 就是 3 个连续的数字。给定任一正整数 N,要求编写程序求出最长连续因子的个数,并输出最小的连续因子序列。

L1-006 连续因子 (20 分) Go语言|Golang

一个正整数 N 的因子中可能存在若干连续的数字。例如 630 可以分解为 3×5×6×7,其中 5、6、7 就是 3 个连续的数字。给定任一正整数 N,要求编写程序求出最长连续因子的个数,并输出最小的连续因子序列。


输入格式:

输入在一行中给出一个正整数 N(1<N<2e31)


输出格式:

首先在第 1 行输出最长连续因子的个数;然后在第 2 行中按 因子1因子2……*因子k 的格式输出最小的连续因子序列,其中因子按递增顺序输出,1 不算在内。


输入样例:

630

结尾无空行

输出样例:

3
5*6*7

结尾无空行

思路:

因为是连续的,所以我们只需找到第一个数字就行了,不过要记录一下一共有多少个这样的连续数字。最后连环输出就可以了。

但是!!!我只拿了18分。。。呜呜呜。。希望能有大佬帮我看看为啥我第四个测试点过不了。。

代码如下:

package main
import (
  "fmt"
  "math"
)
func main() {
  var N int
  var tmp int
  length := 0
  first := 0
  _,_ = fmt.Scan(&N)
  for i := 2; i <= int(math.Sqrt(float64(N)))+1; i++ {  // 使用开方,减少循环次数,注意类型的
    var j int
    tmp = 1
    for j=i ; j<=int(math.Sqrt(float64(N)))+1; j++ {  // 使用开方,减少循环次数,注意类型的
      tmp *= j
      if N % tmp!=0 {
        break
      }
      if j-i>length {
        length  = j-i
        first = i
      }
    }
  }
  if first == 0 {     //特殊情况的考虑
    fmt.Printf("1\n%d",N)
  }else{
    fmt.Printf("%d",length +1)
    fmt.Printf("\n%d",first)
    for i := 1;i<=length ; i++ {
      fmt.Printf("*%d",first+i)
    }
  }
}
相关文章
|
10天前
|
Go
go语言中的数据类型
go语言中的数据类型
11 0
|
16天前
|
Go 开发者
掌握Go语言:Go语言结构体,精准封装数据,高效管理实体对象(22)
掌握Go语言:Go语言结构体,精准封装数据,高效管理实体对象(22)
|
16天前
|
安全 Go
掌握Go语言:Go语言通道,并发编程的利器与应用实例(20)
掌握Go语言:Go语言通道,并发编程的利器与应用实例(20)
|
16天前
|
存储 缓存 安全
掌握Go语言:Go语言中的字典魔法,高效数据检索与应用实例解析(18)
掌握Go语言:Go语言中的字典魔法,高效数据检索与应用实例解析(18)
|
16天前
|
存储 安全 Go
掌握Go语言:Go语言类型转换,无缝处理数据类型、接口和自定义类型的转换细节解析(29)
掌握Go语言:Go语言类型转换,无缝处理数据类型、接口和自定义类型的转换细节解析(29)
|
1天前
|
前端开发 Java Go
开发语言详解(python、java、Go(Golong)。。。。)
开发语言详解(python、java、Go(Golong)。。。。)
|
10天前
|
存储 Java 编译器
go语言基础语法
go语言基础语法
|
16天前
|
存储 缓存 安全
掌握Go语言:Go语言Map,高效键值对集合的应用与注意事项详解(26)
掌握Go语言:Go语言Map,高效键值对集合的应用与注意事项详解(26)
|
16天前
|
存储 安全 编译器
掌握Go语言:精通Go语言范围(range),高级应用及进销存系统实战(25)
掌握Go语言:精通Go语言范围(range),高级应用及进销存系统实战(25)
|
16天前
|
供应链 算法 安全
掌握Go语言:函数精髓,定义、参数、多返回值与应用(14)
掌握Go语言:函数精髓,定义、参数、多返回值与应用(14)