C++ 求素数(10分) 编写程序,求任意两个整数之间所有的素数。


/*题目内容:编写程序,求任意两个整数之间所有的素数。
输入格式:输入两个整数,用空格间隔。注意输入的两个整数谁大谁小是任意的。
输出格式:输出数据占一行,用空格间隔。
输入样例:
100 130
输出样例:
101 103 107 109 113 127
*/
#include <iostream>
#include<cmath>
#include<iomanip>
using namespace std;
int max(int a,int b)
{ int c; 
if(a>b)
    {
        c=a;
        a=b;
        b=c;
    }
return a,b;
}
int main()
{
    int a,b;
    cout<<"输入a  b:";
    cin>>a>>"">>b;
    int max(int a,int b);
int m,k,i,n=0;
bool prime;
for(m=a+1;m<=b;m+=2)
{
prime=true;
k=sqrt(m);
for(i=2;i<=k;i++)
if(m%i==0)
{
prime=false;
break;
}
if(prime)
{
cout<<m<<"\t";
n=n+1;
}
//if(n%n==0)cout<<endl;
}

cout<<endl;
return 0;
}

请问我错在哪了

代码如下,有用请采纳哦!

#include <iostream>

using namespace std;
void function1(int n,int m)
{
    for(int i=n;i<=m;++i)
    {
        int count = 0;
        for(int j=2;j<i;++j)
        {
            if(i%j==0)
            {
                ++count;
                break;
            }
        }
        if(count==0)
            cout<<i<<" ";
    }
    cout<<endl;
}

int main()
{
    int n,m;
    cin >> n >> m;
    function1(100,130);

    return 0;
}

我觉得是这样
#include <bits/stdc++.h>
using namespace std;
int n,m;
bool a[10000001]; //初始化为false, 默认都是质数
int main()
{
cin>>n;
cin>>m;
for(int i=n; i<=sqrt(m); ++i){ //从
if(a[i]==0){ //如果i是质数
for(int j=i; ij<=n; ++j){
a[i
j]=1;
}
}
}
for(int i=n; i<=m; ++i){
if(a[i]==0){
cout<<i<<" ";
}
}
return 0;
}

参考这篇博客,改成输入就好了,https://blog.csdn.net/L_J_Kin/article/details/123974603

错在不应该用一门基础语法还没学会的语言去做题目