uva 196 Spreadsheet 拓扑排序 。坑爹的一题

2024-06-01 22:32

本文主要是介绍uva 196 Spreadsheet 拓扑排序 。坑爹的一题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

uva 196 Spreadsheet

这题字符串处理上还是有点麻烦的,不过也还是可以处理

然后就是拓扑排序, 一开始是用一个个删除度数0的点的方法, 在POJ上过了 POJ数据果断水。。。 在UVA上无限超时。坑爹啊。 后来换成用DFS过了。不容易

PS:这题数据上是说要1 ~ 999 * 1 ~ 1800000多少的数据。。非常大。可是实际上只要开1000*1000的数组就可以过掉了。。 又是坑爹

代码
#include <stdio.h>
#include <string.h>struct SB
{int num;int x[50];int y[50];int rx[55];int ry[55];int z;int zz;int du;int judge;
} map[1005][1005];int t;
int n, m;
int i, j, k;
int ii, jj;
char sb[2005];int dfs(int x, int y)
{int i;if (map[x][y].z == 0)return map[x][y].num;for (i = 0; i < map[x][y].z; i++)  map[x][y].num += dfs(map[x][y].x[i], map[x][y].y[i]);  map[x][y].z = 0;  return map[x][y].num;  
}
int main()
{scanf("%d", &t);while (t --){memset(map, 0, sizeof(map));memset(sb, 0, sizeof(sb));scanf ("%d%d", &m, &n);for (i = 1; i <= n; i ++){getchar();for (j = 1; j <= m; j ++){scanf("%s", sb);int l = strlen(sb);if (sb[0] != '=')  {int num = 0;int f = 0; if (sb[0] == '-') f = 1;  for (k = f; k < l; k ++)  num = num * 10 + sb[k] - '0';  map[i][j].num = num;  if (f == 1) map[i][j].num = -map[i][j].num;    } else  {int column = 0; int row = 0; int pos = 1;  map[i][j].num = 0;  while (pos < l)  {while ((sb[pos] >= 'A') && (sb[pos] <= 'Z')){column = column * 26 + sb[pos]-'A'+1; ++pos;}  while ((pos < l) && (sb[pos] >= '0') && (sb[pos] <= '9')){row = row * 10 + sb[pos] - '0';++ pos;}map[i][j].x[map[i][j].z] = row;map[i][j].y[map[i][j].z] = column;map[i][j].du ++;map[row][column].rx[map[row][column].zz] = i;map[row][column].ry[map[row][column].zz] = j;map[row][column].zz ++;map[i][j].z ++;row = 0; column = 0; ++ pos;  }  }}}for(i = 1; i <= n; i++)  for(j = 1; j <= m; j++)  {if(map[i][j].z) dfs(i, j);}for (i = 1; i <= n; i ++){for (j = 1; j < m; j ++){printf("%d ", map[i][j].num);}printf("%d\n", map[i][m].num);}}return 0;
}


这篇关于uva 196 Spreadsheet 拓扑排序 。坑爹的一题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1022273

相关文章

Python中lambda排序的六种方法

《Python中lambda排序的六种方法》本文主要介绍了Python中使用lambda函数进行排序的六种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录1.对单个变量进行排序2. 对多个变量进行排序3. 降序排列4. 单独降序1.对单个变量进行排序

关于Java内存访问重排序的研究

《关于Java内存访问重排序的研究》文章主要介绍了重排序现象及其在多线程编程中的影响,包括内存可见性问题和Java内存模型中对重排序的规则... 目录什么是重排序重排序图解重排序实验as-if-serial语义内存访问重排序与内存可见性内存访问重排序与Java内存模型重排序示意表内存屏障内存屏障示意表Int

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

uva 10055 uva 10071 uva 10300(水题两三道)

情歌两三首,水题两三道。 好久没敲代码了为暑假大作战热热身。 uva 10055 Hashmat the Brave Warrior 求俩数相减。 两个debug的地方,一个是longlong,一个是输入顺序。 代码: #include<stdio.h>int main(){long long a, b;//debugwhile(scanf("%lld%lld", &

poj 3259 uva 558 Wormholes(bellman最短路负权回路判断)

poj 3259: 题意:John的农场里n块地,m条路连接两块地,w个虫洞,虫洞是一条单向路,不但会把你传送到目的地,而且时间会倒退Ts。 任务是求你会不会在从某块地出发后又回来,看到了离开之前的自己。 判断树中是否存在负权回路就ok了。 bellman代码: #include<stdio.h>const int MaxN = 501;//农场数const int

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直

uva 10061 How many zero's and how many digits ?(不同进制阶乘末尾几个0)+poj 1401

题意是求在base进制下的 n!的结果有几位数,末尾有几个0。 想起刚开始的时候做的一道10进制下的n阶乘末尾有几个零,以及之前有做过的一道n阶乘的位数。 当时都是在10进制下的。 10进制下的做法是: 1. n阶位数:直接 lg(n!)就是得数的位数。 2. n阶末尾0的个数:由于2 * 5 将会在得数中以0的形式存在,所以计算2或者计算5,由于因子中出现5必然出现2,所以直接一

uva 568 Just the Facts(n!打表递推)

题意是求n!的末尾第一个不为0的数字。 不用大数,特别的处理。 代码: #include <stdio.h>const int maxn = 10000 + 1;int f[maxn];int main(){#ifdef LOCALfreopen("in.txt", "r", stdin);#endif // LOCALf[0] = 1;for (int i = 1; i <=