javascript - 알고리즘을 찾고 계십니까? 0000000 시퀀스 증분
举个栗子:0000000递增,格式是这样的:
<code>0000001 0000002 0000003 .....递增到10 0000010 .....递增到100 0000100 .....递增到100000 0100000 </code>
模仿着@G_Koala_C的回答,写了php版的:
<code>for ($i = 0; $i < 100; $i++) { $zero = ''; $k = 7-strlen($i); for ($j = $k; $j >0; $j--) { $zero .= 0; } echo $zero.$i.'<br>'; }</code>
回复内容:
举个栗子:0000000递增,格式是这样的:
<code>0000001 0000002 0000003 .....递增到10 0000010 .....递增到100 0000100 .....递增到100000 0100000 </code>
模仿着@G_Koala_C的回答,写了php版的:
<code>for ($i = 0; $i < 100; $i++) { $zero = ''; $k = 7-strlen($i); for ($j = $k; $j >0; $j--) { $zero .= 0; } echo $zero.$i.'<br>'; }</code>
js写法, 原理就是先算数字的长度,然后在前边补零。现在是到100,你可以把i改到100000
<code>for (var i = 0 ; i <= 100; i ++){ var zero = ""; for (var j = 7-i.toString().length; j > 0; j--) { zero += "0"; } console.log(zero + i); }</code>
其实是补零的问题额,Python 3写这样:
<code>["{:0>7}".format(i) for i in range(1, 100001)]</code>
再提供一个js的写法
<code>Array.from(Array(1000000).keys()).map(function(x){ return "0".repeat(8 - ("" + (x + 1)).length) + (x+1)})</code>
PHP
<code>for ($i=0;$i<=9999999;$i++) echo str_pad($i,7,"0",STR_PAD_LEFT);</code>
提供一个未来可能能使用的方法。。
<code>for (let i = 0; i <= 100; i++) console.log(String(i).padStart(7,'0'))</code>
<code>function incrace(){ console.log((n=>(7-n.length)>0?(new Array(7-n.length+1)).join(0)+n:n)(String(i++))); setTimeout(incrace,500); } var i = 0; incrace(); </code>
写完才发现问题已经解答了…js代码,供参考
JS
<code>var len = 10; //长度 for (var i = 1; i <= 100; i++) { console.log((Array(len).join(0) + Math.abs(i)).slice(-len)); }</code>
来来来...上一套PHP版野路子
<code>// 定义一个位数比结果位数多的初始值 $base_num = 10000000; // 开搞 for ($i = 0; $i < 100; $i++) { echo substr($base_num += $i, -7), "\n"; }</code>
看我C语言的:
<code>for (int i = 0; i < 10000000; i++) { printf("%07d\n", i); }</code>
补零后的长度其实也是可配的:
<code>// 补零后长度, 注意printf的变化~ in len = 7; for (int i = 0; i < 10000000; i++) { printf("%0*d\n", len, i); }</code>
我发现很多回答都不是真正意义上的算法,我还以为类似C语言printf函数的实现呢.
上一个模拟printf函数的C语言实现吧,这个问题不用计算长度
请在支持C99的编译器上运行.(C89不支持)
<code>#include <string.h> #include <stdlib.h> void ltoa(long num, int width, char *str) { static char digs[] = "0123456789";//为了方便扩展十六进制 char ac[width+1];// C99支持; +1 是因为字符串必须以'\0'结尾,但这个不计入字符串长度. int i = width; // 这个变量可以直接用i代替的,但是这个函数是我之前写的,懒得改下面代码 memset(&ac, '0', width); //直接把全部内存先置'0' ac[i] = '\0';//字符串结尾必须是'\0' //后面是整数转字符串的代码,思路就是除法和余数得到每一位数字(进制转换也是同样思想) //例如123 /10 = 12_3 // 12 / 10 = 1_2 // 1 / 10 = 0_1 //你可以看到,余数 3,2,1 倒置过来就是1,2,3. //把 3, 2 ,1 倒置复制到 内存空间就行了. if(num) ac[--i] = digs[num % 10]; num = num / 10; while( 0 < num && 0 < i) { ldiv_t qr = ldiv(num, 10); // ldiv_t 用结构体,主要方便一次性取出余数和商 num = qr.quot; ac[--i] = digs[qr.rem]; // 把0,1,3,4转换成'0','1','2','3',也可用0+'0' 的方法,但是上面已经说明,为了扩展到其他进制方便. } int n = sizeof(ac) - i; memcpy(str, &ac, width +1);//把字符串和\0 复制到缓冲区. } </code>
<code> int max = 一个数字; for (int i = 0; i < max; i++) { String tem = ""; for (int j = 0; j < len - (i + "").toString().length(); j++) { tem = tem + "0"; } System.out.println(tem+i); }</code>
有人把值改成100000以上么
为啥没有C/C++版本啊。
看你们写的这么复杂我就放心了
这还要写什么算法吗?来个mysql版本的:
<code>CREATE TABLE `test` ( `tid` int(7) UNSIGNED ZEROFILL DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8;</code>

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

이 튜토리얼은 PHP를 사용하여 XML 문서를 효율적으로 처리하는 방법을 보여줍니다. XML (Extensible Markup Language)은 인간의 가독성과 기계 구문 분석을 위해 설계된 다목적 텍스트 기반 마크 업 언어입니다. 일반적으로 데이터 저장 AN에 사용됩니다

문자열은 문자, 숫자 및 기호를 포함하여 일련의 문자입니다. 이 튜토리얼은 다른 방법을 사용하여 PHP의 주어진 문자열의 모음 수를 계산하는 방법을 배웁니다. 영어의 모음은 A, E, I, O, U이며 대문자 또는 소문자 일 수 있습니다. 모음이란 무엇입니까? 모음은 특정 발음을 나타내는 알파벳 문자입니다. 대문자와 소문자를 포함하여 영어에는 5 개의 모음이 있습니다. a, e, i, o, u 예 1 입력 : String = "Tutorialspoint" 출력 : 6 설명하다 문자열의 "Tutorialspoint"의 모음은 u, o, i, a, o, i입니다. 총 6 개의 위안이 있습니다

Java 8은 스트림 API를 소개하여 데이터 컬렉션을 처리하는 강력하고 표현적인 방법을 제공합니다. 그러나 스트림을 사용할 때 일반적인 질문은 다음과 같은 것입니다. 기존 루프는 조기 중단 또는 반환을 허용하지만 스트림의 Foreach 메소드는이 방법을 직접 지원하지 않습니다. 이 기사는 이유를 설명하고 스트림 처리 시스템에서 조기 종료를 구현하기위한 대체 방법을 탐색합니다. 추가 읽기 : Java Stream API 개선 스트림 foreach를 이해하십시오 Foreach 메소드는 스트림의 각 요소에서 하나의 작업을 수행하는 터미널 작동입니다. 디자인 의도입니다

캡슐은 3 차원 기하학적 그림이며, 양쪽 끝에 실린더와 반구로 구성됩니다. 캡슐의 부피는 실린더의 부피와 양쪽 끝에 반구의 부피를 첨가하여 계산할 수 있습니다. 이 튜토리얼은 다른 방법을 사용하여 Java에서 주어진 캡슐의 부피를 계산하는 방법에 대해 논의합니다. 캡슐 볼륨 공식 캡슐 볼륨에 대한 공식은 다음과 같습니다. 캡슐 부피 = 원통형 볼륨 2 반구 볼륨 안에, R : 반구의 반경. H : 실린더의 높이 (반구 제외). 예 1 입력하다 반경 = 5 단위 높이 = 10 단위 산출 볼륨 = 1570.8 입방 단위 설명하다 공식을 사용하여 볼륨 계산 : 부피 = π × r2 × h (4

CMS는 콘텐츠 관리 시스템을 의미합니다. 사용자가 고급 기술 지식 없이도 디지털 콘텐츠를 생성, 관리 및 수정할 수 있는 소프트웨어 애플리케이션 또는 플랫폼입니다. CMS를 사용하면 사용자가 콘텐츠를 쉽게 생성하고 구성할 수 있습니다.

배열은 프로그래밍에서 데이터를 처리하는 데 사용되는 선형 데이터 구조입니다. 때로는 배열을 처리 할 때 기존 배열에 새 요소를 추가해야합니다. 이 기사에서는 각 방법에 대한 코드 예제, 출력 및 시간 및 공간 복잡성 분석을 통해 PHP의 배열 끝에 요소를 추가하는 몇 가지 방법에 대해 논의합니다. 배열에 요소를 추가하는 다양한 방법은 다음과 같습니다. 사각형 브래킷 사용 [] PHP에서 배열 끝에 요소를 추가하는 방법은 사각형 브래킷을 사용하는 것입니다 []. 이 구문은 단일 요소 만 추가하려는 경우에만 작동합니다. 다음은 구문입니다. $ array [] = value; 예
