189 8069 5689

第一次双周赛+基础存图-创新互联

第一次双周赛+基础存图

成都创新互联公司致力于成都网站设计、网站制作,成都网站设计,集团网站建设等服务标准化,推过标准化降低中小企业的建站的成本,并持续提升建站的定制化服务水平进行质量交付,让企业网站从市场竞争中脱颖而出。 选择成都创新互联公司,就选择了安全、稳定、美观的网站建设服务!

#include

using namespace std;

char str1[1005],str2[1005];

int a[1005],b[1005],c[2010];

int zhuan(char c) //写个函数把字符转换为十进制

{

if(c>='0' && c<='9')

return c-'0';

else

return c-'A'+10;

}

int main()

{

cin>>str1>>str2;

int len1=strlen(str1);

for(int i=0;i

   a[i+1]=zhuan(str1[len1-i-1]);

int len2=strlen(str2);

for(int i=0;i

b[i+1]=zhuan(str2[len2-i-1]);//把两个字符串倒序放入

int flag=0;//进位数

for(int i=1;i<=len1;++i)

{

       flag=0;//注意每次清零

for(int j=1;j<=len2;++j)

{

c[i+j-1]+=a[i]*b[j]+flag;

flag=c[i+j-1]/16;

c[i+j-1]%=16;

}

c[i+len2]=flag;

}//高精度相乘

int len3=len1+len2;

while(c[len3]==0 && len3>1) len3--;

for(int i=len3;i>=1;i--)

{

if(c[i]>=0 && c[i]<=9)

cout<

else

cout<<(char)(c[i]-10+'A'); 

}//再把这个数转为16进制

return 0;

}

查找每一个答案即可

#include

using namespace std;

int n,m,a[100005],y;

bool  check(int x)

{

int t = 0;

for (int i = 1; i<= n; i++)

{

if (a[i]< t)//装不完弹就挂了

return false;

if (a[i]<= t + m)//装完弹且在射程内

t += x;

else

{

t += (a[i] - t - m);//装完弹还不在射程内

t += x;

}

}

return true;

}

int main()

{

cin>>n>>m;

for (int i=1;i<=n;i++) cin>>a[i];

sort(a+1,a+n+1);

int L=0,R=a[n];

while (L+1

{

   int mid=(L+R)/2;

   if (check(mid)) L=mid;

   else R=mid;

}//二分答案

cout<

}

第四题:反向链表

#include

const int X=1e5+5;

using namespace std;

int main(){

int Data[X],Next[X],list[X];

int FirstAdd,N,K;

cin>>FirstAdd>>N>>K;

for(int i=0;i

{

   int tmpAdd,tmpData,tmpNext;

   cin>>tmpAdd>>tmpData>>tmpNext;

   Data[tmpAdd] = tmpData;

   Next[tmpAdd] = tmpNext;

}

int sum=0;   // 累计有效结点数

while(FirstAdd!=-1)

{   // 当尾结点为 -1 时结束

   list[sum++] = FirstAdd;   // 记录所有Address

   FirstAdd = Next[FirstAdd];  // 找下一个结点

}

for(int i=0;i

){  // 每 K 个结点一个区间

   for(int j=0;j

   {  // 反转链表

          int t = list[i+j];

          list[i+j] = list[i+K-j-1];

          list[i+K-j-1] = t;

   }

}

for(int i=0;i

   printf("%05d %d %05d\n",list[i],Data[list[i]],list[i+1]);

printf("%05d %d -1\n",list[sum-1],Data[list[sum-1]]);

return 0;

}

#include

using namespace std;

const double N=1e-7;

double a,b,c,d,p,q;

int T;

double check(double l,double r)

{

double x1=a*r*r*r+b*r*r+c*r+d;//右边界验证

while(r-l>N)

{

   double mid=(r+l)/2;

   double x2=a*mid*mid*mid+b*mid*mid+c*mid+d;//判断中点

   if (x1*x2<0) l=mid;//两点乘积小于零那么往右找

   else r=mid;//否则往左找

}

}

int main()

{

cin>>T;

while(T--)

{

cin>>a>>b>>c>>d>>p>>q;

  double j1=((-2*b)-sqrt(4*b*b-12*a*c)) / (6*a);    

  double j2=((-2*b)+sqrt(4*b*b-12*a*c)) / (6*a);    //先求导然后就可以分出三个区间

  if (j1>j2) swap(j1,j2);//确保区间区间是递增的

  printf("%.6lf %.6lf %.6lf",check(p,j1),check(j1,j2),check(j2,q));//分区间查找一下

}

看了学长的教学就会了

#include

using namespace std;

const int N=1005;

vectorG[N];

bool vis[N];

int st,ed,sum,cnt[N],n,m,x,y;

void dfs(int now)

{

if (now==ed)//走到终点

{

   sum++;

   for (int i=1;i<=n;i++)

   if (vis[i]) cnt[i]++;//标记走过几次

   return;

}

for (int i=0;i

{

   int to =G[now][i];//下一步

   if (!vis[to])//判断没走过

   {

          vis[to]=true;//标记为走过

          dfs(to);//接着搜下一步

          vis[to]=false;//再次标记为没走过

   }

}

}

int main()

{

cin>>n>>m;

for (int i=1;i<=m;i++)

{

   cin>>x>>y;

   G[x].push_back(y);

   G[y].push_back(x);//无向图基础存图

}

cin>>st>>ed;

vis[st]=true;//把起点标记为走过

dfs(st);

int ans=0;

for (int i=1;i<=n;i++)

{

   if (cnt[i]==sum) ans++;

}

ans=ans-2;//减去起点和终点

cout<

return 0;

}

这题知道反向dfs后就简单了,连我都独立搞定了

#include

using namespace std;

const int N=100005;

int u,v,n,m,vis[N],ans[N];

vectorG[N];

void dfs(int x,int y)

{

if (vis[x]) return;

ans[x]=y;//把第几个点序号放入ans数组

vis[x]=true;//标记为走过

for (int i=0;i

    dfs(G[x][i],y);//把第x行的图搜一遍

}

int main()

{

cin>>n>>m;

for (int i=1;i<=m;i++)

{

    cin>>u>>v;

   G[v].push_back(u); //反向存

}      //有向图基础存图

for (int i=n;i>=1;i--) dfs(i,i);//从后往前搜

for (int i=1;i<=n;i++) cout<

return 0;

}

#include

using namespace std;

const int N = 10010;

int n, m;

vectorg[N];

bool vis[N];

int a[N],sum[3];

bool dfs(int now, int col)

{

vis[now] = true;//标记走过

a[now] = col;

sum[col]++;

for (int i = 0; i< g[now].size(); i++)

  {

int to = g[now][i];//下一步

if (vis[to] && a[to] == a[now])

return false;//相邻了,不行

else if (!vis[to])

{

if (!dfs(to, 3 - col))

     return false;

}

}

return true;

}

int main()

{

cin>>n>>m;

for (int i = 1; i<= m; i++)

{

int u, v;

cin>>u>>v;

g[u].push_back(v);

g[v].push_back(u);

}//存图

int ans = 0;

for (int i = 1; i<= n; i++)

if (!vis[i])//没走过

{

 sum[1] = sum[2] = 0;

if (!dfs(i,1))

{

     printf("Impossible");

     return 0;

}//没有符合条件的情况

ans += min(sum[1], sum[2]);//加上小的那个

}

cout<

return 0;

}

你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧


文章名称:第一次双周赛+基础存图-创新互联
标题路径:http://gzruizhi.cn/article/dpdico.html

其他资讯