팩토리얼구할때
불꾼
질문 제목 :
스택오버플로우라는데
이것이 왜 일어나는거죠
질문 내용 :
일단 팩토리얼 계산하는 건데요 뭐 int를 쓴데다 pow리턴형이 long이니까 12!까지밖에 안구해 지긴 하지만..
저렇게 1~n까지의 수중 소수를 먼저 구하고 그걸로 소인수분해해서 소인수 거듭제곱을 모두 곱하는 식으로 했는데요
num과 size에 십만까지는 되는데 백만부터는 스택오버플로우라고 에러가 나네요
어찌된 걸까요그리고 저기서 팩토리얼을 제대로 나타내려면 자료형을 따로 만들어야 할듯한데 어떻게 하죠? 관련 자료들이라도 좀 갈켜줘요
#include stdio.h
#include math.h
#define num 1000000
#define size 1000000
int a[size];
int r[size];
void getprime()
{
int z=0;
for(int k=0; ksize; k++)
{
a[k]=r[k]=0;
}
static int prime[num+1];
int i,j,m,limit;
for(i=0; i=num; i++) prime[i]=1;
limit= (int)sqrt( num);
for( i=2; i=limit; i++)
{
if( prime[i] == 1)
{
j= 2;
for(m= j*i; m= num; m=j*i)
{
prime[m]=0;
j++;
}
}
}
for(i=2; i=num; i++)
if( prime[i]== 1){
a[z]=i;
z++;
}
}
int main()
{
unsigned long fact=1;
int cnt=0;
int b[num];
for (int w=0; wnum; w++)
{
b[w]=w+1;
}
getprime();
for (int e=0; esize; e++)
{
if(a[e]==0)
continue;
else
cnt++;
}
for(int y=0; ynum; y++)
{
while(1)
{
for(int u=0; ucnt; u++){
if(b[y]%a[u]==0){
b[y]=b[y]/a[u];
r[u]++;
}
if (b[y]==1)
break;
}
if (b[y]==1)
break;
}
}
for(int o=0(int o=0; ocnt; o++)
{
fact*=pow(a[o],r[o]);
}
printf(%d,fact);
return 0;
}
-
쇼코홀릭
소수를 구해서 소인수분해 하는 겁니다.
-
딥레드
소수를 왜 구하죠?
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676182 | 숫자 순서대로 배열하는법 | 권뉴 | 2024-11-24 |
2676152 | 기본적인거 하나 질문드립니다. | 개미 | 2024-11-24 |
2676124 | 함수선언관련 질문이에요~...털썩..수정완료 (2) | 가지 | 2024-11-24 |
2676092 | C언어 책 (2) | 아서 | 2024-11-24 |
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
2676033 | 배열 기초연습중 발생하는 에러 ㅠㅜ... | Creative | 2024-11-23 |
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |