Athene.

55

Athene.
1天前

Athene.
15天前

# include[HTML_REMOVED]

using namespace std;
const int M=1010;
int v[M],w[M];
int f[M];//j体积下前i个物体的最大价值
int main()
{
int n,m;
cin>>n>>m;
for(int i=1;i<=n;i)cin>>v[i]>>w[i];
//f[0][0-m]=0 0件物品的时候价值是0 初始化可以省略 全局变量都是0
for(int i=1;i<=n;i
)
{
for(int j=v[i];j<=m;j++)
{

            f[j]=max(f[j],f[j-v[i]]+w[i]);
}
}
cout<<f[m]<<endl;
return 0;


}

Athene.
15天前

# include[HTML_REMOVED]

using namespace std;
const int M=1010;
int v[M];
int w[M];
int f[M];//j体积下前i个物体的最大价值
int main()
{
int n,m;
cin>>n>>m;
for(int i=1;i<=n;i)cin>>v[i]>>w[i];
//f[0][0-m]=0 0件物品的时候价值是0 初始化可以省略 全局变量都是0
for(int i=1;i<=n;i
)
{
for(int j=m;j>=v[i];j–)
{
f[j]=max(f[j],f[j-v[i]]+w[i]);
//else情况不需要操作，保持即可，忽略不写
}
}
cout<<f[m]<<endl;
return 0;
}

Athene.
1个月前

# include[HTML_REMOVED]

using namespace std;
int e(int a,int b,int &x,int &y)
{
if(b==0)
{
x=1,y=0;
return a;
}
int x1,y1,g;
g=e(b,a%b,x1,y1);
x=y1,y=x1-a/b*y1;
return g;
}
int main()
{
int n,a,b,x,y;
cin>>n;
while(n–)
{
cin>>a>>b;
e(a,b,x,y);
cout<<x<<” “<<y<<endl;
}
return 0;
}

Athene.
1个月前

# include[HTML_REMOVED]

using namespace std;
typedef long long ll;
ll qmi(int a,int b,int p)
{
ll res=1;
while(b)
{
if(b&1)res=resa%p;
a=(ll)a
a%p;
b>>=1;
}
return res;
}
int main()
{
int n;
cin>>n;
while(n–)
{
int a,p;
cin>>a>>p;
if(a%p==0) puts(“impossible”);
else cout<<qmi(a,p-2,p)<<endl;
}
return 0;
}

Athene.
1个月前

# include[HTML_REMOVED]

using namespace std;
typedef long long ll;
int main()
{
ll n;
cin>>n;
while(n–)
{
ll x;
cin>>x;
ll res=x;
for(ll i=2;i<=x/i;i++)
{
if(x%i==0)
{
res=res/i(i-1);
while(x%i==0)x/=i;
}
}
if(x>1)res=res/x
(x-1);
cout<<res<<endl;
}
}

Athene.
1个月前

# include[HTML_REMOVED]

using namespace std;
long long qmi(long long a,int b,int p)
{
long long res=1;
while (b)
{
if(b&1)res=resa%p;
b>>=1;
a=a
a%p;
}
return res;
}
int main()
{
int n;
scanf(“%d”,&n);
while(n–)
{
int a,b,p;
scanf(“%d%d%d”,&a,&b,&p);
printf(“%lld\n”,qmi(a,b,p));
}
return 0;
}

Athene.
3个月前

# include[HTML_REMOVED]

using namespace std;
const int N=10010;
//初始化
void init()
{
idx=0;
}
//将x插到头节点
{
e[idx]=x;
idx;
}
//将x插入到下标是K的点后面
{
e[idx]=x;
ne[idx]=ne[k];
ne[k]=idx;
idx
;
}
//将下标为k的点后面的点删除
void remove(int k)
{
ne[k]=ne[ne[k]];
}
int main()
{
int m;
cin>>m;
init();
while(m–)
{
int k,x;
char op;
cin>>op;
if(op==’H’)
{
cin>>x;
}
else if(op==’D’)
{
cin>>k;